鍍金池/ 問答/Python  C  C++  Ruby  網(wǎng)絡安全/ Python 隊列Queue和管道Pipes是如何實現(xiàn)的?

Python 隊列Queue和管道Pipes是如何實現(xiàn)的?

問題1:

隊列和管道好像是基于文件的?
就是把信息發(fā)送到特定文件?再從文件中讀取?
如果是這樣,那么這個文件生成在哪個目錄?隱藏嗎?對用戶可見嗎?如果在linux下,對用戶權限如何?
如果不是基于文件,那么是如何實現(xiàn)?

問題2:

# 創(chuàng)建一個隊列
q = Queue()
# 阻塞模式下直接讀取會阻塞(因為沒數(shù)據(jù)傳入隊列)
value = q.get()

阻塞表示程序知道我還得取得一個值,就等待一個值發(fā)送進來,那么總要有個檢測間隔嘛?
這個檢測間隔是多少?多少秒?對,就是時間是多少?

為什么問這個?
因為,如果自己寫的話:

while True:
    if flag == True:
        #do sonming #
        break

flag遲遲不變?yōu)門rue的話直接cpu就滿了,所以我一般寫如上代碼都會加一個time.sleep(n),讓程序中斷n秒后再檢測Flag的值

while True:
    if flag == True:
        #do sonming #
        break
    time.sleep(1)

這樣完全不用考慮消耗cpu的問題,因為1秒對于cpu來說"太長"了
在線程中更簡單的是,直接使用隊列,隊列傳入一個flag值進來讓程序繼續(xù)運行,完全不用while True:

# 
q = Quant()
# 定義線程函數(shù)
def thread_fun():
    # 要是沒有值進來下面這句就無限阻塞
    q.get()
    # 當有某個值q.put()時就會接著運行
    #do sonming #

(不知道說的對不對,不對請指出,下面這句)
我這久都是這么寫的,我覺得這樣可以很好的控制,最主要的是隊列和管道不用考慮鎖的問題,這樣寫不知道效率如何,還是我考慮多了
我猜測q.get()里的實現(xiàn)肯定有while True啊,那么他要不要控制檢測的頻率??

還是文件系統(tǒng)的檢測有什么不一樣?
因為我還寫過一個一個進程寫一個文件,一個進程讀同一個文件的,讀的進程讀到文件的末尾,可以接著readline,只是返回''(空字符串)就是了,這樣我肯定不能讓讀的進程無限讀文件啊,消耗cpu和IO,后來我就加了time.sleep(0.5),我覺得對于人來看,0.5秒的間隔夠了

但是我比較貪心啊,想追求效率,就是q.get()如果內部不用循環(huán)檢測的話,那么效率應該會比較高,請問其實如何實現(xiàn)的?

想再開個問題問協(xié)程的,這個和協(xié)程有沒有關系?(還在學習)
算了,不問了,以上
謝謝

回答
編輯回答
浪婳

1、隊列和管道如果你指的是multiprocessing,那多進程之間通信是在內存層面實現(xiàn)的
2、q.get() https://docs.python.org/3.6/l...
你沒有傳參數(shù),所以會一直等到隊列的下一個數(shù)據(jù)為止,你可以設置q.get(timeout=10) 10秒后拿不到數(shù)據(jù)就超時

2017年4月15日 06:47