Python3,開(kāi)一個(gè)線(xiàn)程,間隔1秒把一個(gè)遞增的數(shù)字寫(xiě)入隊(duì)列,再開(kāi)一個(gè)線(xiàn)程,從隊(duì)列中取出數(shù)字并打印到終端
#! /usr/bin/env python3import timeimport threadingimport queue# 一個(gè)線(xiàn)程,間隔一定的時(shí)間,把一個(gè)遞增的數(shù)字寫(xiě)入隊(duì)列# 生產(chǎn)者class Producer(threading.Thread): def __init__(self, work_queue): super().__init__() # 必須調(diào)用 self.work_queue = work_queue def run(self): num = 1 while True: self.work_queue.put(num) num = num+1 time.sleep(1) # 暫停1秒# 一個(gè)線(xiàn)程,從隊(duì)列取出數(shù)字,并顯示到終端class Printer(threading.Thread): def __init__(self, work_queue): super().__init__() # 必須調(diào)用 self.work_queue = work_queue def run(self): while True: num = self.work_queue.get() # 當(dāng)隊(duì)列為空時(shí),會(huì)阻塞,直到有數(shù)據(jù) print(num)def main(): work_queue = queue.Queue() producer = Producer(work_queue) producer.daemon = True # 當(dāng)主線(xiàn)程退出時(shí)子線(xiàn)程也退出 producer.start() printer = Printer(work_queue) printer.daemon = True # 當(dāng)主線(xiàn)程退出時(shí)子線(xiàn)程也退出 printer.start() work_queue.join() # 主線(xiàn)程會(huì)停在這里,直到所有數(shù)字被get(),并且task_done(),因?yàn)闆](méi)有調(diào)用task_done(),所在這里會(huì)一直阻塞,直到用戶(hù)按^Cif __name__ == '__main__': main()
queue是線(xiàn)程安全的,從多個(gè)線(xiàn)程訪(fǎng)問(wèn)時(shí)無(wú)需加鎖。
如果在work_queue.get()之后調(diào)用work_queue.task_done(),那么在隊(duì)列空時(shí)work_queue.join()會(huì)返回。
這里work_queue.put()是間隔一定時(shí)間才往隊(duì)列放東西,如果調(diào)用work_queue.task_done(),在數(shù)字1被get()后,隊(duì)列空時(shí),join()就返回,程序就結(jié)束了。
也就是程序只打印了1然后就退出了。
所以在這種使用情景下,不能調(diào)用task_done(),程序會(huì)一直循環(huán)下去。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注