溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python線程間通信之隊列怎么創(chuàng)建

發(fā)布時間:2023-04-26 14:46:37 來源:億速云 閱讀:132 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“python線程間通信之隊列怎么創(chuàng)建”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

為什么需要線程間通信

一個人的力量是有限的,但是團(tuán)隊合作可以發(fā)揮更大的作用。而團(tuán)隊協(xié)作需要交流和通信來有效的分配任務(wù)和協(xié)調(diào)工作,來保證保時保量的完成工作。

為什么線程間需要通信呢?這就好比一個團(tuán)隊需要完成一個工作,但是這個工作周期性比較長,復(fù)雜度也比較高,此時就需要團(tuán)隊協(xié)作了,領(lǐng)導(dǎo)就把工作分為了n份,ab、c員工每次領(lǐng)取1份工作,做完了再向老板同步,并且領(lǐng)取新的工作,這樣的話,工作很快就做完了嘛。

將線程代入上面的例子,在某些任務(wù)中,可能需要多個線程來完成同樣的任務(wù),所以線程間通信是為了線程之間的協(xié)作和同步,更快的完成任務(wù)。

線程間通信方式有哪些

python多線程編程中,線程間通信方法主要有以下幾種:

  • 共享變量

這是最常用,也是用的最多的方式,這個很好理解,在同一進(jìn)程中,多個線程有一部分內(nèi)存是共用進(jìn)程的,所以多個線程可以使用“共享變量”的方式共享同一份數(shù)據(jù),通過對該變量的讀寫操作來實現(xiàn)線程間通信。

  • 隊列

python中,為我們提供了隊列的標(biāo)準(zhǔn)庫Queue,它是標(biāo)準(zhǔn)庫中的一個安全隊列的實現(xiàn)。作用是可以在多個線程間共享數(shù)據(jù),主要用法為通過get方法將數(shù)據(jù)放入隊列,get方法將數(shù)據(jù)從隊列中取出來,

  • 管道

python管道是通過multiprocessing庫中的Pipe實現(xiàn)的,可以在2個線程之間任意傳遞數(shù)據(jù),而且是雙向通信的,主要用法為通過send方法發(fā)送數(shù)據(jù),通過recv方法接收數(shù)據(jù)。

除此之外,還有其他方法,例如 借助第三方工具,比如redis等。

線程間通信案例之隊列

共享變量,我們之前就已經(jīng)用過了,比如上一節(jié),我們自己實現(xiàn)了python的讀寫鎖,就用到了共享變量的方式。這里就不再過多闡述了。這里將介紹一下管道的案例:

隊列多用于生產(chǎn)者消費者,在python中,是使用queue模塊下的Queue方法,創(chuàng)建一個新的隊列語句為:

queues = queue.Queue()

其中,Queue可以傳入一個maxsize,它將作為隊列的最大值,默認(rèn)的話,是無限制。

想要往隊列中寫入數(shù)據(jù)的話,使用put方法即可,例如,向隊列寫入字符串"123",我們僅需要調(diào)用put方法即可,例如:

queues.put("123")

而想要從隊列中獲取數(shù)據(jù)的話,需要使用get方法,例如:

data = queues.get()
print(data)

除此之外,還有隊列其他常用的方法,如: qsize()會返回隊列中元素的數(shù)量,empty()會判斷隊列是否為空,full()會判斷隊列是否已經(jīng)滿了。

這里舉一個文件分發(fā)下載的例子,我們需要定義一個生產(chǎn)者,用于發(fā)布任務(wù),定義多個消費者,用于執(zhí)行任務(wù),代碼如下:

python線程間通信之隊列怎么創(chuàng)建

在上述代碼中,我們定義了生產(chǎn)者和消費者2個類,其初始方法__init__會傳入隊列信息,生產(chǎn)者有定義了2個方法,一個是put,是將元素放入隊列中,還有一個是qsize,是返回當(dāng)前隊列的個數(shù)。而消費者只定義了一個方法get,上面寫了一個死循環(huán),向隊列獲取數(shù)據(jù),每獲取到一個數(shù)據(jù),休息15秒。

在主函數(shù)中,我們定義了一個公共的隊列queues,而后定義了生產(chǎn)者p和消費者q,二者都傳入了同一個隊列queues。最后我們寫了3個線程,用于執(zhí)行消費者qget方法。 和 調(diào)用一個生產(chǎn)者方法put

執(zhí)行結(jié)果為:

python線程間通信之隊列怎么創(chuàng)建

上述結(jié)果展現(xiàn)的是,生產(chǎn)者生成數(shù)據(jù),而消費者接收。file_0file_9都只被消費了一次,可見隊列是自己保證了線程競爭問題的。

“python線程間通信之隊列怎么創(chuàng)建”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI