Python多線程和隊列操作實例
Python3,開一個線程,間隔1秒把一個遞增的數字寫入隊列,再開一個線程,從隊列中取出數字并打印到終端
#! /usr/bin/env python3
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 = 1
while True:
self.work_queue.put(num)
num = num+1
time.sleep(1) # 暫停1秒
# 一個線程,從隊列取出數字,并顯示到終端
class Printer(threading.Thread):
def __init__(self, work_queue):
super().__init__() # 必須調用
self.work_queue = work_queue
def run(self):
while True:
num = self.work_queue.get() # 當隊列為空時,會阻塞,直到有數據
print(num)
def main():
work_queue = queue.Queue()
producer = Producer(work_queue)
producer.daemon = True # 當主線程退出時子線程也退出
producer.start()
printer = Printer(work_queue)
printer.daemon = True # 當主線程退出時子線程也退出
printer.start()
work_queue.join() # 主線程會停在這里,直到所有數字被get(),并且task_done(),因為沒有調用task_done(),所在這里會一直阻塞,直到用戶按^C
if __name__ == '__main__':
main()
queue是線程安全的,從多個線程訪問時無需加鎖。
如果在work_queue.get()之后調用work_queue.task_done(),那么在隊列空時work_queue.join()會返回。
這里work_queue.put()是間隔一定時間才往隊列放東西,如果調用work_queue.task_done(),在數字1被get()后,隊列空時,join()就返回,程序就結束了。
也就是程序只打印了1然后就退出了。
所以在這種使用情景下,不能調用task_done(),程序會一直循環(huán)下去。
https://docs.python.org/3/library/queue.html
相關文章
Sklearn調優(yōu)之網格搜索與隨機搜索原理詳細分析
這篇文章主要介紹了Sklearn調優(yōu)之網格搜索與隨機搜索原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-02-02
python獲得文件創(chuàng)建時間和修改時間的方法
這篇文章主要介紹了python獲得文件創(chuàng)建時間和修改時間的方法,涉及Python針對文件屬性的相關操作技巧,需要的朋友可以參考下2015-06-06
詳解python中靜態(tài)方法staticmethod用法
本文主要介紹了python中靜態(tài)方法staticmethod用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07
Python接入MySQL實現增刪改查的實戰(zhàn)記錄
這篇文章主要給大家介紹了關于Python接入MySQL實現增刪改查的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03

