码迷,mamicode.com
首页 > 编程语言 > 详细

7.3.4 - 并发多线程 守护线程

时间:2018-03-06 23:09:26      阅读:194      评论:0      收藏:0      [点我收藏+]

标签:技术分享   start   main   code   open   body   gif   并发   eve   

一 守护线程

无论是进程还是线程,都遵循:守护xxx会等待主xxx运行完毕后被销毁

需要强调的是:运行完毕并非终止运行

1、对主进程来说,运行完毕指的是主进程代码运行完毕

2、对主线程来说,运行完毕指的是主线程所在的进程内所有非守护线程统统运行完毕,主线程才算运行完毕

详细解释:

1、主进程在其代码结束后就已经算运行完毕了(守护进程在此时就被回收),然后主进程会一直等非守护的子进程都运行完毕后回收子进程的资源(否则会产生僵尸进程),才会结束,

2、主线程在其他非守护线程运行完毕后才算运行完毕(守护线程在此时就被回收)。因为主线程的结束意味着进程的结束,进程整体的资源都将被回收,而进程必须保证非守护线程都运行完毕后才能结束。
from threading import Thread
import time

def foo():
    print(123)
    time.sleep(1)
    print("end123")

def bar():
    print(456)
    time.sleep(3)
    print("end456")

if __name__ == __main__:
    t1=Thread(target=foo)
    t2=Thread(target=bar)

    t1.daemon=True
    t1.start()
    t2.start()
    print("main-------")
技术分享图片
123
456
main-------
end123
end456
运行结果

1. t1.start() 会打印 123

2. t2.start()会打印456

3. print("main-------") 会打印main-------

此时主线程在等待其他非守护进程结束后才结束

7.3.4 - 并发多线程 守护线程

标签:技术分享   start   main   code   open   body   gif   并发   eve   

原文地址:https://www.cnblogs.com/caimengzhi/p/8516932.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!