python线程setDaemon

在python中,主线程结束后,会默认等待子线程结束后,主线程才退出,如下:

#coding=utf-8
import threading
import time


class mythread(threading.Thread):
	def __init__(self):
		super().__init__()
	
	def run(self):
		for i in range(5):
			time.sleep(1)
		print("mythread end")


if __name__ == "__main__":
	print("main start")
	thd = mythread()
	thd.setDaemon(True)   ##主线程在结束时结束子线程thd
	thd.start()
如下面生产者、消费者模型,queue.get()队列为空时阻塞,线程consumer1还是被退出,但不会输出"consumer end"

#coding=utf-8
import time
import threading
import queue

class producer(threading.Thread):
	def __init__(self,work_queue):
		super().__init__()             ##父类初始化
		self.work_queue = work_queue
	def run(self):
		num = 10
		while (num > 0):
			self.work_queue.put(num)
			num = num - 1
			time.sleep(1)
		print("producer end")

class consumer(threading.Thread):
	def __init__(self,work_queue):
		super(consumer,self).__init__()   ##父类初始化
		self.work_queue = work_queue
	def run(self):
		while True:
			num = self.work_queue.get()  ##queue为空时阻塞
			print("get: " + str(num))
		print("consumer end")

def main():
	work_queue = queue.Queue()
	producer1 = producer(work_queue)
	producer1.start()

	consumer1 = consumer(work_queue)
	consumer1.setDaemon(True)
	consumer1.start()

	##work_queue.join()

if __name__ == '__main__':
	main()
E:\MySelf\myfile\My Python>threadtest.py
get: 10
get: 9
get: 8
get: 7
get: 6
get: 5
get: 4
get: 3
get: 2
get: 1
producer end

E:\MySelf\myfile\My Python>




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `setDaemon()` 是 `threading.Thread` 类的一个方法,用于设置线程是否为守护线程。守护线程是在后台运行的线程,当主线程结束时,它们也会随之结束。而非守护线程则会一直运行直到自己完成任务或被强制停止。 调用`setDaemon(True)` 将线程设置为守护线程,调用 `setDaemon(False)` 将线程设置为非守护线程。默认情况下,线程为非守护线程。 需要注意的是,一旦一个线程被设置为守护线程,它的子线程也会被自动设置为守护线程。因此,如果有非守护线程的子线程在守护线程中运行,那么这些子线程可能在主线程结束之前被强制退出,因为它们的运行不再是必须的。 ### 回答2: 在使用Python中的多线程编程时,可以使用threading模块中的setdaemon方法来设置线程的守护属性。守护线程是指在主线程结束时,守护线程也会随之结束,不会阻塞主线程的退出。 setdaemon方法接受一个布尔值参数,用于设置线程的守护属性。当参数为True时,线程被设置为守护线程;当参数为False时,线程被设置为非守护线程。 守护线程的生命周期与主线程紧密相关,当主线程结束时,守护线程会立即停止执行。这对于一些后台运行的任务非常有用,比如日志记录、监控等。在这些情况下,如果主线程退出,守护线程也不应该继续执行。 需要注意的是,守护线程并不会影响其他非守护线程的执行。即使所有非守护线程都结束,守护线程依然会在主线程退出时自动终止。此外,守护线程通常不能保证完整地执行完成,因为它们的生命周期与主线程紧密相关。 在使用setdaemon方法时,需要在线程启动之前调用该方法设置线程的守护属性。示例如下: ```python import threading def task(): # 守护线程的具体任务逻辑 pass if __name__ == "__main__": t = threading.Thread(target=task) t.setdaemon(True) # 设置为守护线程 t.start() ``` 在上述示例中,创建了一个线程t,并将其设置为守护线程。在线程启动后,当主线程退出时,守护线程t也会立即停止执行。 总结来说,setdaemon方法用于将线程设置为守护线程,通过该方法可以控制守护线程的生命周期与主线程的关联。 ### 回答3: Python中的threading模块提供了一个Thread类,允许我们创建和操作线程。其中包含的一个方法是setDaemon(),它接受一个布尔值作为参数,并且用于设置线程是否为守护线程。 在Python中,守护线程是指会在主线程结束后自动退出的线程。当所有的非守护线程都结束时,Python解释器会自动退出。换句话说,如果主线程结束了,守护线程会随之结束,不管它是否还在执行。而非守护线程会等待所有的子线程执行完毕后才会结束。 setDaemon()方法的作用就是设置线程对象为守护线程。通过调用该方法,并将参数设置为True,我们可以将线程设置为守护线程;如果将参数设置为False,则线程为非守护线程。 守护线程常用于在后台执行一些不重要的任务,或者用于监控和管理所有的其他线程。通常情况下,守护线程会一直运行,直到主线程结束,但是并不保证守护线程执行完所有的代码。 需要注意的是,setDaemon()方法必须在start()方法调用之前设置,否则会抛出RuntimeError异常。 总之,setDaemon()方法使得我们能够控制线程的生命周期,将线程设置为守护线程可以在主线程结束时自动退出,而非守护线程则会等待所有的子线程执行完毕后再退出。这在多线程编程中是非常有用的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值