Python線程編程解決異步線程中速度不同的方案
在計(jì)算機(jī)的實(shí)際相關(guān)的應(yīng)用中你是否對(duì)兩個(gè)相關(guān)異步線程速度產(chǎn)生不同時(shí),而產(chǎn)生一些相關(guān)的問題,針對(duì)這一相關(guān)問題,Python線程編程就可以巧妙的解決相關(guān)的問題,以下是文章的具體介紹。
我們經(jīng)常會(huì)采用生產(chǎn)者/消費(fèi)者關(guān)系的兩個(gè)線程來處理一個(gè)共享緩沖區(qū)的數(shù)據(jù)。例如一個(gè)生產(chǎn)者線程接受用戶數(shù)據(jù)放入一個(gè)共享緩沖區(qū)里,等待一個(gè)消費(fèi)者線程對(duì)數(shù)據(jù) 取出處理。但是如果緩沖區(qū)的太小而生產(chǎn)者和消費(fèi)者兩個(gè)異步線程的速度不同時(shí),容易出現(xiàn)一個(gè)線程等待另一個(gè)情況。
為了盡可能的縮短共享資源并以相同速度工作 的各線程的等待時(shí)間,我們可以使用一個(gè)“隊(duì)列”來提供額外的緩沖區(qū)。
創(chuàng)建一個(gè)“隊(duì)列”對(duì)象
- import Queue
- myqueue = Queue.Queue(maxsize = 10)Queue.Queue
類即是一個(gè)隊(duì)列的同步實(shí)現(xiàn)。隊(duì)列長(zhǎng)度可為無限或者有限??赏ㄟ^Queue的構(gòu)造函數(shù)的可選參數(shù)maxsize來設(shè)定隊(duì)列長(zhǎng)度。如果maxsize小于1就表示隊(duì)列長(zhǎng)度無限。將一個(gè)值放入隊(duì)列中
- myqueue.put(10)
調(diào)用隊(duì)列對(duì)象的put()方法在隊(duì)尾插入一個(gè)項(xiàng)目。put()有兩個(gè)參數(shù),***個(gè)item為必需的,為插入項(xiàng)目的值;第二個(gè)block為可選參數(shù),默認(rèn)為1。如果隊(duì)列當(dāng)前為空且block為1,put()方法就使調(diào)用線程暫停,直到空出一個(gè)數(shù)據(jù)單元。如果block為0,put方法將引發(fā)Full異常。將一個(gè)值從隊(duì)列中取出
- myqueue.get()
調(diào)用隊(duì)列對(duì)象的get()方法從隊(duì)頭刪除并返回一個(gè)項(xiàng)目??蛇x參數(shù)為block,默認(rèn)為1。如果隊(duì)列為空且block為1,get()就使調(diào)用線程暫停,直至有項(xiàng)目可用。如果block為0,隊(duì)列將引發(fā)Empty異常。我們用一個(gè)例子來展示如何使用
- Queue# queue_example.py
以上的內(nèi)容就是對(duì)Python線程編程的相關(guān)實(shí)際應(yīng)用方案的部分介紹。
【編輯推薦】
- python教程在例10.4 備份腳本的代碼的介紹
- python開發(fā)windows程序中的編譯代碼示例與介紹
- Python vim檢查編碼在文件中的對(duì)應(yīng)編碼的介紹
- Python目錄文件在實(shí)際應(yīng)用操作方案詳解
- Python os.walk 在遍歷目錄中的實(shí)際應(yīng)用步驟