守护线程daemon

如下代码:

from threading import Thread
import time


def func1(n):
    time.sleep(10)
    print(n)


t = Thread(target=func1, args=(1,))
t.start()
print("主线程结束")

结果是:先打印 主线程结束,等十秒之后打印1

如下代码,加入守护线程:

from threading import Thread
import time


def func1(n):
    time.sleep(10)
    print(n)


t = Thread(target=func1, args=(1,))
t.daemon = Thread
t.start()
print("主线程结束")

结果是,只打印了 主线程结果,没打印子线程结果,也没等10秒,直接结束。

所以守护线程是随着主线程的结束而结束。

再看一个现象:

from threading import Thread
import time


def func1(n):
    time.sleep(10)
    print(n)


def func2(n):
    time.sleep(3)
    print('子线程2', n*n)


t = Thread(target=func1, args=(1,))
t.daemon = Thread
t.start()
t2 = Thread(target=func2, args=(2,))
t2.start()
print("主线程结束")

结果是,先打印 主线程结束,等3秒之后打印 子线程2 4  然后没有等待子线程1就直接结束了。

所以,守护线程是随着主线程结束,然后等着其他子线程的结束而结束。

与守护进程对比:

守护进程:守护进程是随着主进程代码的结束而结束。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值