时间:2021-05-22
多线程编程当中, 线程的存在形态比较抽象. 通过前台线程\后台线程, 可以有效理解线程运行顺序.(复杂的多线程程序可以通过设置线程优先级实现)
后台线程与前台线程的直接区别是,
1)setDaemon(True): 当主线程退出时,后台线程随机退出;
2)setDaemon(False)(默认情况): 当主线程退出时,若前台线程还未结束,则等待所有线程结束,相当于在程序末尾加入join().
实例:
例子描述:主线程调用giveures给出字符串s的md5摘要,同时在giveures当中启动一个线程打印字符串内容.
1.前台线程
import timefrom hashlib import md5from threading import Threaddef pmd(md): time.sleep(3) #使用sleep使得该线程比主线程晚结束 print("backend recording:",md)def giveures(s): md = md5(s.encode('utf-8')) res = md.digest() t = Thread(target=pmd,args=(s,)) #t.setDaemon(True) 默认情况:t.setDaemon(False) t.start() return ress = 'chrisyang'res = giveures(s)print(res)exit()运行结果:
b'h#\x86|\xa0\xeff\xc7u\xba\x18\xb2\xd2s\xf9\x9e'
backend recording: chrisyang
第一行打印出来之后,隔3s后打印出第二行,说明在等待pmd线程结束后进程才退出.
2.后台线程
运行结果:
b'h#\x86|\xa0\xeff\xc7u\xba\x18\xb2\xd2s\xf9\x9e'
pmd线程因为sleep挂起一段时间,因此在主线程完成时还未结束就被强制退出了.
知识归纳:
以上的是前后台线程的外在区别,至于内在区别,转自Stack Overflow的一个精炼回答:
后台线程的责任是为整个主线程提供服务,如保持网络连接(发送keep-alive心跳包),负责内存管理与垃圾回收(实际上JVM就是这样做的). 因此这些线程与实际提供应用服务的线程有了逻辑上的”前/后”的概念,而如果主线程已经退出,那么后台线程也没有存在的必要.
如果没有这一机制,那么我们在主线程完成之后,还必须逐个地检查后台线程,然后在主线程退出之前,逐个地关闭它们. 有了前后线程的区分, 我们只需要负责管理前台线程, 完成主要的逻辑处理之后退出即可.
原文:
Daemon Threads Explanation
以上这篇python使用Thread的setDaemon启动后台线程教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java中线程分为两种类型:用户线程和守护(服务)线程。通过Thread.setDaemon(false)设置为用户线程;通过Thread.setDaemon(
本文实例讲述了Java使用Thread创建多线程并启动操作。分享给大家供大家参考,具体如下:按照教程实现了一个单线程的创建,但是单线程的创建于启动并不是很有实用
Python多线程的实例详解一)线程基础1、创建线程:thread模块提供了start_new_thread函数,用以创建线程。start_new_thread
Python的线程操作在旧版本中使用的是thread模块,在Python27和Python3中引入了threading模块,同时thread模块在Python3
之前用python的多线程,总是处理不好进程和线程之间的关系。后来发现了join和setDaemon函数,才终于弄明白。下面总结一下。1.使用join函数后,主