欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python進(jìn)程間通信Queue實(shí)例解析

 更新時(shí)間:2018年01月25日 15:50:23   作者:王輝_Python  
這篇文章主要介紹了Python進(jìn)程間通信Queue實(shí)例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下

本文研究的主要是Python進(jìn)程間通信Queue的相關(guān)實(shí)例,具體如下。

1.Queue使用方法:

  • Queue.qsize():返回當(dāng)前隊(duì)列包含的消息數(shù)量;
  • Queue.empty():如果隊(duì)列為空,返回True,反之False ;
  • Queue.full():如果隊(duì)列滿了,返回True,反之False;
  • Queue.get():獲取隊(duì)列中的一條消息,然后將其從列隊(duì)中移除,可傳參超時(shí)時(shí)長(zhǎng)。
  • Queue.get_nowait():相當(dāng)Queue.get(False),取不到值時(shí)觸發(fā)異常:Empty;
  • Queue.put():將一個(gè)值添加進(jìn)數(shù)列,可傳參超時(shí)時(shí)長(zhǎng)。
  • Queue.put_nowait():相當(dāng)于Queue.get(False),當(dāng)隊(duì)列滿了時(shí)報(bào)錯(cuò):Full。

2.Queue使用實(shí)例:

來,上代碼:

#!/usr/bin/env python3

import time
from multiprocessing import Process,Queue

q = Queue() #創(chuàng)建列隊(duì),不傳數(shù)字表示列隊(duì)不限數(shù)量
for i in range(11):
  q.put(i)

def A():
  while 1:
    try:
      num = q.get_nowait()
      print('我是進(jìn)程A,取出數(shù)字:%d'%num)
      time.sleep(1)
    except :
      break

def B():
  while 1:
    try:
      num = q.get_nowait()
      print('我是進(jìn)程B,取出數(shù)字:%d'%num)
      time.sleep(1)
    except :
      break

p1 = Process(target = A)
p2 = Process(target = B)
p1.start()
p2.start()

此程序是在隊(duì)列中加入10個(gè)數(shù)字,然后用2個(gè)進(jìn)程來取出。

運(yùn)行結(jié)果:

我是進(jìn)程A,取出數(shù)字:0
我是進(jìn)程B,取出數(shù)字:1
我是進(jìn)程A,取出數(shù)字:2
我是進(jìn)程B,取出數(shù)字:3
我是進(jìn)程A,取出數(shù)字:4
我是進(jìn)程B,取出數(shù)字:5
我是進(jìn)程B,取出數(shù)字:6
我是進(jìn)程A,取出數(shù)字:7
我是進(jìn)程B,取出數(shù)字:8
我是進(jìn)程A,取出數(shù)字:9
我是進(jìn)程B,取出數(shù)字:10

3.使用進(jìn)程池Pool時(shí),Queue會(huì)出錯(cuò),需要使用Manager.Queue:

上代碼

#!/usr/bin/env python3

import time
from multiprocessing import Pool,Manager,Queue

q = Manager().Queue()
for i in range(11):
  q.put(i)

def A(i):
  num = q.get_nowait()
  print('我是進(jìn)程%d,取出數(shù)字:%d'%(i,num))
  time.sleep(1)
      

pool = Pool(3)

for i in range(10):
  pool.apply_async(A,(i,))

pool.close()
pool.join()

運(yùn)行結(jié)果:

我是進(jìn)程1,取出數(shù)字:0
我是進(jìn)程0,取出數(shù)字:1
我是進(jìn)程2,取出數(shù)字:2
我是進(jìn)程4,取出數(shù)字:3
我是進(jìn)程3,取出數(shù)字:4
我是進(jìn)程5,取出數(shù)字:5
我是進(jìn)程6,取出數(shù)字:6
我是進(jìn)程7,取出數(shù)字:7
我是進(jìn)程8,取出數(shù)字:8
我是進(jìn)程9,取出數(shù)字:9

當(dāng)把Manager().Queue()直接換成Queue(),可能會(huì)出現(xiàn)資源混亂,缺少進(jìn)程。

4.主進(jìn)程定義了一個(gè)Queue類型的變量,并作為Process的args參數(shù)傳給子進(jìn)程processA和processB,兩個(gè)進(jìn)程一個(gè)向隊(duì)列中寫數(shù)據(jù),一個(gè)讀數(shù)據(jù)。

import time
from multiprocessing import Process,Queue

MSG_QUEUE = Queue(5)

def startA(msgQueue):
  while True:
    if msgQueue.empty() > 0:
      print 'queue is empty %d' % (msgQueue.qsize())
    else:
      msg = msgQueue.get()
      print 'get msg %s' % (msg,)
    time.sleep(1)

def startB(msgQueue):
  while True:
    msgQueue.put('hello world')
    print 'put hello world queue size is %d' % (msgQueue.qsize(),)
    time.sleep(3)

if __name__ == '__main__':
  processA = Process(target=startA,args=(MSG_QUEUE,))
  processB = Process(target=startB,args=(MSG_QUEUE,))

  processA.start()
  print 'processA start..'

  processB.start()
  print 'processB start..'

其打印的結(jié)果如下:

C:\Python27\python.exe E:/outofmemory/test/queuetest/queuetest.py
processA start..
processB start..
queue is empty 0
put hello world queue size is 1
get msg hello world
queue is empty 0
queue is empty 0
put hello world queue size is 1
get msg hello world
queue is empty 0
queue is empty 0
put hello world queue size is 1

總結(jié)

以上就是本文關(guān)于Python進(jìn)程間通信Queue實(shí)例解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • 詳解Python中遞歸函數(shù)的原理與使用

    詳解Python中遞歸函數(shù)的原理與使用

    如果一個(gè)函數(shù),可以自己調(diào)用自己,那么這個(gè)函數(shù)就是一個(gè)遞歸函數(shù)。本文將詳細(xì)講解Python中遞歸函數(shù)的使用與原理,感興趣的可以了解一下
    2022-05-05
  • 在Python中使用next()方法操作文件的教程

    在Python中使用next()方法操作文件的教程

    這篇文章主要介紹了在Python中使用next()方法操作文件的教程,是Python入門中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-05-05
  • Python函數(shù)參數(shù)分類原理詳解

    Python函數(shù)參數(shù)分類原理詳解

    這篇文章主要介紹了Python函數(shù)參數(shù)分類原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Python中Pyspider爬蟲框架的基本使用詳解

    Python中Pyspider爬蟲框架的基本使用詳解

    這篇文章主要介紹了Python中Pyspider爬蟲框架的基本使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • python多線程高級(jí)鎖condition簡(jiǎn)單用法示例

    python多線程高級(jí)鎖condition簡(jiǎn)單用法示例

    這篇文章主要介紹了python多線程高級(jí)鎖condition簡(jiǎn)單用法,結(jié)合實(shí)例形式分析了condition對(duì)象常用方法及相關(guān)使用技巧,需要的朋友可以參考下
    2019-11-11
  • Python如何發(fā)送Syslog日志

    Python如何發(fā)送Syslog日志

    這篇文章主要介紹了Python如何發(fā)送Syslog日志問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Python獲取當(dāng)前函數(shù)名稱方法實(shí)例分享

    Python獲取當(dāng)前函數(shù)名稱方法實(shí)例分享

    這篇文章主要介紹了Python獲取當(dāng)前函數(shù)名稱方法實(shí)例分享,具有一定借鑒價(jià)值
    2018-01-01
  • Python中super()的理解以及應(yīng)用場(chǎng)景實(shí)例

    Python中super()的理解以及應(yīng)用場(chǎng)景實(shí)例

    在python中關(guān)于類的定義可以分為兩種:老式類&新式類,在新式類中有這么一種方法super( ),下面這篇文章主要給大家介紹了關(guān)于Python中super()的理解以及應(yīng)用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • Python生成器之yield詳解

    Python生成器之yield詳解

    這篇文章主要介紹了Python生成器yield,yield除了作為生成器的標(biāo)志以外,還有一個(gè)「返回值」的功能,我們知道return也有這個(gè)功能,那么它跟return的這個(gè)返回值有什么區(qū)別呢,本文將詳細(xì)的介紹yield,需要的朋友可以參考下
    2023-05-05
  • Django初步使用Celery處理耗時(shí)任務(wù)和定時(shí)任務(wù)問題

    Django初步使用Celery處理耗時(shí)任務(wù)和定時(shí)任務(wù)問題

    這篇文章主要介紹了Django初步使用Celery處理耗時(shí)任務(wù)和定時(shí)任務(wù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評(píng)論