上海做网站的多吗wordpress小说站数据库
news/
2025/9/22 21:20:11/
文章来源:
上海做网站的多吗,wordpress小说站数据库,免费下载微信小程序,成都app制作开发团队队列#xff08;Queue#xff09;
在Python的queue模块中#xff0c;Queue类是一个线程安全的队列实现#xff0c;用于在多线程编程中安全地交换信息。它遵循先入先出#xff08;FIFO#xff09;的原则。Queue类提供了几种主要的方法#xff1a;
put(item): 将一个项目…队列Queue
在Python的queue模块中Queue类是一个线程安全的队列实现用于在多线程编程中安全地交换信息。它遵循先入先出FIFO的原则。Queue类提供了几种主要的方法
put(item): 将一个项目放入队列中。如果队列已满则此方法将阻塞直到队列中有空间可用。get(): 从队列中移除并返回一个项目。如果队列为空则此方法将阻塞直到队列中有项目可用。task_done(): 表示之前入队的一个任务已经完成。通常由使用get()的消费者线程调用。每调用一次get()随后就应该调用一次task_done()来告诉队列该任务已处理完毕。join(): 阻塞调用线程直到队列中的所有项目都被处理并调用task_done()方法。这通常用于等待由队列消费的所有工作项完成。
并发编程中的线程
在Python中threading模块提供了基本的线程和锁支持。每个Thread对象代表了一个线程的执行。线程之间共享全局解释器锁GIL这意味着在任意时刻只有一个线程可以执行Python字节码。然而对于I/O密集型任务如文件读写、网络请求和等待密集型任务如数据库查询、外部API调用多线程仍然可以提高程序的总体性能因为线程在等待时可以释放GIL允许其他线程运行。
示例详解
下面是对之前示例的详细解释包括一些注意事项和潜在的改进点
import queue
import threading
import time
import randomdef worker(q, job_type):while True: # 注意这里的无限循环需要外部机制来中断if job_type producer:item random.randint(1, 100)q.put(item)print(f{threading.current_thread().name} 生产了 {item})time.sleep(random.random()) # 模拟耗时操作elif job_type consumer:item q.get()print(f{threading.current_thread().name} 消费了 {item})time.sleep(random.random()) # 模拟耗时操作q.task_done() # 告诉队列这个任务已完成# 创建一个队列
q queue.Queue(maxsize10) # 可选地设置队列的最大大小# 创建并启动生产者线程
producers [threading.Thread(targetworker, args(q, producer), namef生产者-{i1}) for i in range(2)]
for t in producers:t.daemon Truet.start()# 创建并启动消费者线程
consumers [threading.Thread(targetworker, args(q, consumer), namef消费者-{i1}) for i in range(3)]
for t in consumers:t.daemon Truet.start()# 注意由于生产者线程是无限循环的下面的q.join()将永远不会返回
# 除非有某种机制来停止生产者线程例如使用共享变量或threading.Event
# 为了示例的简洁性这里省略了停止生产者的代码# 假设我们在某个时刻决定停止所有线程
# 这可以通过设置共享变量或使用threading.Event来实现
# ...这里省略了停止线程的代码# 主线程通常不会在这里等待因为它会立即继续执行后面的代码
# 但为了示例的完整性我们在这里添加了一个简单的阻塞以便可以看到一些输出
try:while True:time.sleep(1)
except KeyboardInterrupt:print(主线程被中断尝试优雅地关闭所有线程...)# 在这里添加关闭所有线程的代码如果有的话# 注意由于我们设置了daemonTrue主线程结束时守护线程也会自动结束# 但这通常不是优雅关闭线程的好方法注意事项
无限循环生产者线程中的无限循环需要外部机制来中断否则它们将永远运行下去。优雅关闭在实际应用中你需要实现一种机制来优雅地关闭线程比如使用共享变量、threading.Event或queue.Empty异常。GIL虽然Python的GIL限制了多线程在CPU密集型任务上的并行性但它对于I/O密集型任务和等待密集型任务仍然很有用。守护线程在这个示例中我们使用了
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/910408.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!