偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Python同步隊(duì)列正確應(yīng)用方式解析

開發(fā)
Python同步隊(duì)列的實(shí)現(xiàn)是一個(gè)比較重要的操作技巧。在實(shí)際編程中,我們會(huì)通過這一操作技術(shù)獲得更多的幫助,以完成一些特定功能。

我們今天將會(huì)通過Python同步隊(duì)列的相關(guān)介紹,來詳細(xì)分析一下這一編程語言中的多線程應(yīng)用。希望對(duì)此又需要的朋友們可以通過本文介紹的內(nèi)容充分的掌握這一應(yīng)用技巧,以方便將來的實(shí)際應(yīng)用。#t#

我們經(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ì)象

  1. import Queue  
  2. 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ì)列中

 

  1. 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ì)列中取出

 

  1. 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è)Python同步隊(duì)列例子來展示如何使用Queue# queue_example.py

  1. from Queue import Queue  
  2. import threading  
  3. import random  
  4. import time  
  5. # Producer thread  
  6. class Producer(threading.Thread):  
  7. def __init__(self, threadname, queue):  
  8. threading.Thread.__init__(self, name = threadname)  
  9. self.sharedata = queue 
  10. def run(self):  
  11. for i in range(20):  
  12. print self.getName(),’adding’,i,’to queue’  
  13. self.sharedata.put(i)  
  14. time.sleep(random.randrange(10)/10.0)  
  15. print self.getName(),’Finished’  
  16. # Consumer thread  
  17. class Consumer(threading.Thread):  
  18. def __init__(self, threadname, queue):  
  19. threading.Thread.__init__(self, name = threadname)  
  20. self.sharedata = queue 
  21. def run(self):  
  22. for i in range(20):  
  23. print self.getName(),’got a value:’,self.sharedata.get()  
  24. time.sleep(random.randrange(10)/10.0)  
  25. print self.getName(),’Finished’  
  26. # Main thread  
  27. def main():  
  28. queue = Queue()  
  29. producer = Producer(’Producer’, queue)  
  30. consumer = Consumer(’Consumer’, queue)  
  31. print ‘Starting threads …’  
  32. producer.start()  
  33. consumer.start()  
  34. producer.join()  
  35. consumer.join()  
  36. print ‘All threads have terminated.’  
  37. if __name__ == ‘__main__’:  
  38. main() 

 

Python同步隊(duì)列示例代碼中實(shí)現(xiàn)了兩個(gè)類:生產(chǎn)者類Producer和消費(fèi)者類Consumer。前者在一個(gè)隨機(jī)的時(shí)間內(nèi)放入一個(gè)值到隊(duì)列queue中然后顯示出來,后者在一定隨機(jī)的時(shí)間內(nèi)從隊(duì)列queue中取出一個(gè)值并顯示出來。

責(zé)任編輯:曹凱 來源: 博客園
相關(guān)推薦

2010-01-25 11:29:33

Android計(jì)時(shí)器

2010-03-04 13:30:11

Python file

2010-02-22 14:09:08

WCF Dispose

2010-03-05 15:01:29

Python解析XML

2010-03-03 17:33:52

Python讀取XML

2010-02-05 14:12:46

C++聲明放置

2010-03-04 14:51:21

Python Conf

2021-07-02 16:13:01

區(qū)塊鏈金融數(shù)據(jù)庫

2009-12-07 14:38:14

PHP foreach

2010-05-28 15:16:40

MySQL 資源

2010-03-04 09:40:52

Python Clas

2010-02-22 10:42:12

WCF Stream

2010-05-25 18:01:35

linux MySQL

2010-05-28 19:20:36

MySQL mysql

2010-03-04 14:02:51

Python大小寫

2010-02-05 17:49:24

C++常量引用

2010-07-21 10:50:48

SQL Server存

2010-07-26 17:43:34

SQL Server

2010-02-01 15:26:44

C++ inline函

2010-08-18 16:45:40

IBM DB2 Cat
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)