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

本文详细解析了Python threading模块中的setDaemon和join方法。通过实例演示了这两种方法如何控制主线程与子线程之间的等待行为,以及设置守护线程的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

.join()

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

import threading
from time import ctime, sleep

def 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没有执行完,就随着程序一同结束了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值