【多进程与多线程】threading中setDaemon与join

来源:互联网 发布:飞豆打印软件 编辑:程序博客网 时间:2024/05/16 17:14

在threading中setDaemon和join都是用来设置等待
首先要明确的是:
假设子线程是t
无论是t.setDaemon() 还是 t.join的等待都是相对于主线程来说的。

.join()

t.join()的作用是,当t在执行时,主线程在join处暂停,只有当t结束运行时,才继续执行join下面的语句
如以下程序:

import threadingfrom time import ctime, sleepdef act1():    for i in range(2):        print("act1 is running at %s" %ctime())        sleep(2)def act2():    for i in range(2):        print("act2 is running at %s" %ctime())        sleep(4)threads = []t1 = threading.Thread(target=act1)threads.append(t1)t2 = threading.Thread(target=act2)threads.append(t2)if __name__ == '__main__':    for t in threads:        t.start()    print("befor join at %s" %ctime())    t.join()    print("after join")    print("finished at %s" %ctime())

其运行结果是
这里写图片描述

运行时在befor语句后有停顿,看时间可以发现,主进程是在befor语句执行之后,遇到join语句开始等待t的执行,然后4秒后,t执行完再执行after语句。

.setDaemon

t.setDaemon()中的参数可以是True或False
这里首先要明确一点,t.setDaemon()一定要在t.start()语句之前,否则程序会无限挂起。

参数为False

当为False时,与不设置效果一样,即t执行,主线程也执行,主线程执行完以后,等待t执行完,然后程序结束。
程序修改为:

if __name__ == '__main__':    for t in threads:        print("befor")        t.setDaemon(False)        t.start()        print("after")    print("finished at %s" %ctime())

执行结果为:
这里写图片描述
程序执行时再finnished at 后停顿
说明主线程和t一同执行,执行完后等待t执行完,结束程序

参数为True

当为True时,是将t设置为守护线程。即,t执行时主线程不暂停继续执行,当主线程执行完了,无论t是否执行完,都一同结束。
程序修改为:

if __name__ == '__main__':    for t in threads:        print("befor")        t.setDaemon(True)        t.start()        print("after")    print("finished at %s" %ctime())

运行结果为:
这里写图片描述
程序执行期间没有停顿,并且从结果上可以看到,t没有执行完,就随着程序一同结束了。

阅读全文
0 0
原创粉丝点击