这篇文章主要讲解了python使用线程的setDaemon启动后台线程的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
多线程编程当中,线程的存在形态比较抽象。通过前台线程\后台线程,可以有效理解线程运行顺序。(复杂的多线程程序可以通过设置线程优先级实现)
<强>后台线程与前台线程的直接区别是,强>
1) setDaemon(真正的):当主线程退出时,后台线程随机退出;
2) setDaemon (False)(默认情况):当主线程退出时,若前台线程还未结束,则等待所有线程结束,相当于在程序末尾加入加入()。
实例:
例子描述:主线程调用giveures给出字符串年代的md5摘要,同时在giveures当中启动一个线程打印字符串内容。
1。前台线程
进口时间 从hashlib进口md5 从线程进口线程 def pmd (md): time . sleep(3) #使用睡眠使得该线程比主线程晚结束 print(“后台录音:“,md) def giveures (s): md=md5 (s.encode (& # 39; utf - 8 # 39;)) res=md.digest () t=线程(目标=pmd, arg游戏=(s)) # t.setDaemon(真正的)默认情况:t.setDaemon(假) t.start () 返回res s=& # 39; chrisyang& # 39; res=giveures (s) 打印(res) 退出()
运行结果:
b # 39; h x86 | # \ \ xa0 \ xeff \ xc7u \ xba \ x18 \ xb2 \ xd2s \ xf9 \ x9e& # 39;
引用>
后台记录:chrisyang第一行打印出来之后,隔3 s后打印出第二行,说明在等待pmd线程结束后进程才退出。
2。后台线程
进口时间 从hashlib进口md5 从线程进口线程 def pmd (md): time . sleep(3) #使用睡眠使得该线程比主线程晚结束 print(“后台录音:“,md) def giveures (s): md=md5 (s.encode (& # 39; utf - 8 # 39;)) res=md.digest () t=线程(目标=pmd, arg游戏=(s)) t.setDaemon(真正的) t.start () 返回res s=& # 39; chrisyang& # 39; res=giveures (s) 打印(res) 退出()运行结果:
b # 39; h x86 | # \ \ xa0 \ xeff \ xc7u \ xba \ x18 \ xb2 \ xd2s \ xf9 \ x9e& # 39;
引用>pmd线程因睡眠为挂起一段时间,因此在主线程完成时还未结束就被强制退出了。
以上的是前后台线程的外在区别,至于内在区别,转自堆栈溢出的一个精炼回答:
后台线程的责任是为整个主线程提供服务,如保持网络连接(发送保活心跳包),负责内存管理与垃圾回收(实际上JVM就是这样做的)。因此这些线程与实际提供应用服务的线程有了逻辑上的“前/后”的概念,而如果主线程已经退出,那么后台线程也没有存在的必要。
如果没有这一机制,那么我们在主线程完成之后,还必须逐个地检查后台线程,然后在主线程退出之前,逐个地关闭它们。有了前后线程的区分,我们只需要负责管理前台线程,完成主要的逻辑处理之后退出即可。
看完上述内容,是不是对python使用线程的setDaemon启动后台线程的方法有进一步的了解,如果还想学习更多内容,欢迎关注行业资讯频道。
python使用线程的setDaemon启动后台线程的方法