python threading中的join和setDaemon方法

python 多线程的threading中的join和setDaemon方法

join():通俗的将就是阻止子线程随着主线程的结束而结束

setDaemon():设置子线程是否随着主线程的结束而结束, 其中:

setDaemon(True) : 设置子线程随着主线程的结束而结束

setDaemon(False) 等价于join() :设置子线程不随着主线程的结束而结束

修改http://blog.youkuaiyun.com/sjyu_ustc/article/details/71080834代码如下:

#!/usr/bin/python
# -*- coding: utf-8 -*-

import threading,time

def test(loop, sec):
    print 'start loop', loop, 'at:', time.ctime()
    time.sleep(sec)
    print 'loop', loop, 'done at:', time.ctime()

def main():
    print 'starting at:', time.ctime()
    thpool = []
    for i in xrange(10):
        th = threading.Thread(target= test,args= (i,2))
        th.start()
        thpool.append(th)
    for th in thpool:
        th.join()
    print 'all Done at:', time.ctime()

if __name__ == '__main__':
        main()
结果:

starting at: Tue May  2 14:31:41 2017
start loop 0 at: Tue May  2 14:31:41 2017
start loop 1 at: Tue May  2 14:31:41 2017
start loop 2 at: Tue May  2 14:31:41 2017
start loop 3 at: Tue May  2 14:31:41 2017
start loop 4 at: Tue May  2 14:31:41 2017
start loop 5 at: Tue May  2 14:31:41 2017
start loop 6 at: Tue May  2 14:31:41 2017
start loop 7 at: Tue May  2 14:31:41 2017
start loop 8 at: Tue May  2 14:31:41 2017
start loop 9 at: Tue May  2 14:31:41 2017
loop 0 done at: Tue May  2 14:31:43 2017
loop 1 done at: looploop  4 loopdone at:  Tue May  2 14:31:43 2017
2Tue May  2 14:31:43 2017
 done at: Tue May  2 14:31:43 2017
3 done at: Tue May  2 14:31:43 2017
loop 5 done at: Tue May  2 14:31:43 2017
loop 6 done at: Tue May  2 14:31:43 2017
loop 7 done at: Tue May  2 14:31:43 2017
loop 8 done at: Tue May  2 14:31:43 2017
loop 9 done at: Tue May  2 14:31:43 2017
all Done at: Tue May  2 14:31:43 2017

可以看出修改前join方法使得每个子线程顺序执行,所有子线程执行完毕后,主线程才退出。 修改后,所有子线程几乎同时执行,之后主线程执行在退出。

修改为setDaemon方法,继续观察:

#!/usr/bin/python
# -*- coding: utf-8 -*-

import threading,time

def test(loop, sec):
    print 'start loop', loop, 'at:', time.ctime()
    time.sleep(sec)
    print 'loop', loop, 'done at:', time.ctime()

def main():
    print 'starting at:', time.ctime()
    for i in xrange(10):
        th = threading.Thread(target= test,args= (i,2))
        th.setDaemon(True)
        th.start()
        
    print 'all Done at:', time.ctime()

if __name__ == '__main__':
        main()

结果:

starting at: Tue May  2 14:57:48 2017
start loop 0 at: Tue May  2 14:57:48 2017
start loop 1 at: Tue May  2 14:57:48 2017
start loop 2 at: Tue May  2 14:57:48 2017
start loop 3 at: Tue May  2 14:57:48 2017
start loop 4 at: Tue May  2 14:57:48 2017
start loop 5 at: Tue May  2 14:57:48 2017
start loop 6 at: Tue May  2 14:57:48 2017
start loop 7 at: Tue May  2 14:57:48 2017
start loop 8 at: Tue May  2 14:57:48 2017
start loop 9 at:all Done at: Tue May  2 14:57:48 2017
 Tue May  2 14:57:48 2017
可以看出子线程都还没执行完,因为主线程退出也都随着主线程退出了

#!/usr/bin/python
# -*- coding: utf-8 -*-

import threading,time

def test(loop, sec):
    print 'start loop', loop, 'at:', time.ctime()
    time.sleep(sec)
    print 'loop', loop, 'done at:', time.ctime()

def main():
    print 'starting at:', time.ctime()
    for i in xrange(10):
        th = threading.Thread(target= test,args= (i,2))
        th.setDaemon(False)
        th.start()
        
    print 'all Done at:', time.ctime()

if __name__ == '__main__':
        main()
结果:

starting at: Tue May  2 15:01:46 2017
start loop 0 at: Tue May  2 15:01:46 2017
start loop 1 at: Tue May  2 15:01:46 2017
start loop 2 at: Tue May  2 15:01:46 2017
start loop 3 at: Tue May  2 15:01:46 2017
start loop 4 at: Tue May  2 15:01:46 2017
 start loop 5 at: Tue May  2 15:01:46 2017
start loop 6 at: Tue May  2 15:01:46 2017
start loop 7 at: Tue May  2 15:01:46 2017
start loop 8 at: Tue May  2 15:01:46 2017
start loop 9 all Done at: Tue May  2 15:01:46 2017
at: Tue May  2 15:01:46 2017
loop 0 done at: Tue May  2 15:01:48 2017
loop 5 done at: Tue May  2 15:01:48 2017
 loop 3 done at:loop 2 done at: Tue May  2 15:01:48 2017
 Tue May  2 15:01:48 2017
 loop 1 done at: Tue May  2 15:01:48 2017
loop 4 done at: Tue May  2 15:01:48 2017
loop 6 done at: Tue May  2 15:01:48 2017
loop 7 done at: Tue May  2 15:01:48 2017
loop 8 done at: Tue May  2 15:01:48 2017
loop 9 done at: Tue May  2 15:01:48 2017
设置为false后,主线程退出后,子线程并没随着主线程的退出而退出


### 回答1: 在 Pythonthreading 模块中,setDaemon() 方法是用来设置线程为守护线程的方法。守护线程是一种特殊的线程,它会随着主线程的结束而自动退出,而不管它是否完成了自己的任务。 如果一个线程被设置为守护线程,那么它不会阻止 Python 解释器退出。这对于一些需要在后台运行的任务非常有用,比如日志记录、定时任务等。 setDaemon() 方法的语法如下: threading.Thread.setDaemon(daemonic) 其中,daemonic 参数是一个布尔值,表示线程是否为守护线程。如果 daemonic 为 True,那么线程就被设置为守护线程;否则,线程就是普通线程。 例如,可以使用以下代码将一个线程设置为守护线程: ``` import threading def worker(): while True: print('Worker is running...') time.sleep(1) t = threading.Thread(target=worker) t.setDaemon(True) # 设置为守护线程 t.start() # 主线程结束,守护线程也会自动退出 ``` ### 回答2: 在Python中,threading模块的setDaemon方法用于设置线程的守护属性。守护线程是一种后台线程,它会随着主线程的结束而自动退出,无论守护线程是否执行完毕。而非守护线程则会等待所有守护线程执行完毕才会退出。 当调用线程的setDaemon(True)方法后,该线程就被设置为守护线程。守护线程的特点是,当所有的非守护线程结束后,守护线程会自动退出,不论它是否执行完毕。守护线程的目的通常是为了提供一种服务或者监控的功能,它并不关心它的工作是否完成,只要主线程执行完毕就可以退出。 守护线程的用途可举例如下: - 后台日志记录:当主线程运行时,守护线程可以记录日志信息,不干扰主线程的运行。 - 定时任务监控:守护线程可以周期性地执行某些操作,如备份文件、清理缓存等。 - 后台检测功能:守护线程可以检测某些任务的状态,并在需要时进行相应的处理。 需要注意的是,守护线程不能创建子线程,因为子线程没有被设置为守护线程,所以只有等到主线程执行完毕后才退出。此外,守护线程中的代码不能含有涉及I/O操作的部分,因为程序退出时,这些I/O操作可能会被中断导致数据丢失。 总之,使用setDaemon方法可以将线程设置为守护线程,使其在主线程结束时自动退出。在合适的情况下,守护线程可以提供一些后台服务或监控功能,从而增强多线程程序的灵活性功能性。 ### 回答3: `setDaemon` 是 Python 中 `threading` 模块中的一个方法,该方法用于设置线程是否为后台线程。 在多线程编程中,有两种类型的线程:前台线程后台线程。前台线程是主程序创建的线程,它会阻塞主程序的执行直到线程执行完毕。而后台线程是在主程序执行完毕后自动退出的线程。 当一个线程被设置为后台线程时,它会随着主线程的结束而结束,不论该线程是否执行完毕。而如果一个线程为前台线程,则必须等到该线程执行完毕才能退出程序。 语法:`thread.setDaemon(boolean)` `setDaemon` 方法接受一个布尔值参数,当参数为 `True` 时,将该线程设置为后台线程,当参数为 `False` 时,将该线程设置为前台线程。 一般来说,如果主程序只需等待前台线程执行完毕,而对于后台线程的执行无需关心,可以将后台线程设置为后台线程。这样可以确保主程序可以及时退出,而无需等待后台线程的运行完毕。但需要注意的是,设置线程为后台线程后,对于任何未结束的任务,都不会通过 `join` 等待它的结束。 需要注意的是,`setDaemon` 方法必须在 `start` 方法之前调用,否则会引发异常。 下面是一个使用 `setDaemon` 方法的例子: ```python import threading def my_func(): for i in range(3): print("This is a background thread.") thread = threading.Thread(target=my_func) thread.setDaemon(True) # 将线程设置为后台线程 thread.start() print("This is the main thread.") ``` 以上代码中,`my_func` 函数是一个后台线程,它将会在主线程结束后自动退出。主程序中的 `print` 语句会在主线程执行完毕后打印输出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值