Python多進程池 multiprocessing Pool用法示例
本文實例講述了Python多進程池 multiprocessing Pool用法。分享給大家供大家參考,具體如下:
1. 背景
由于需要寫python程序, 定時、大量發(fā)送htttp請求,并對結(jié)果進行處理。
參考其他代碼有進程池,記錄一下。
2. 多進程 vs 多線程
- c++程序中,單個模塊通常是單進程,會啟動幾十、上百個線程,充分發(fā)揮機器性能。(目前c++11有了std::thread編程多線程很方便,可以參考我之前的博客)
- shell腳本中,都是多進程后臺執(zhí)行。({ ...} &, 可以參考我之前的博客,實現(xiàn)shell并發(fā)處理任務(wù))
- python腳本有多線程和多進程。由于python全局解鎖鎖的GIL的存在,一般建議 CPU密集型應(yīng)該采用多進程充分發(fā)揮多核優(yōu)勢,I/O密集型可以采用多線程。
盡管Python完全支持多線程編程, 但是解釋器的C語言實現(xiàn)部分在完全并行執(zhí)行時并不是線程安全的。
實際上,解釋器被一個全局解釋器鎖保護著,它確保任何時候都只有一個Python線程執(zhí)行。
GIL最大的問題就是Python的多線程程序并不能利用多核CPU的優(yōu)勢 (比如一個使用了多個線程的計算密集型程序只會在一個單CPU上面運行)。
3. multiprocessing pool使用例子
對Pool對象調(diào)用join()方法會等待所有子進程執(zhí)行完畢,調(diào)用join()之前必須先調(diào)用close(),讓其不再接受新的Process了
#coding=utf-8
import logging
import time
from multiprocessing import Pool
logging.basicConfig(level=logging.INFO, filename='logger.log')
class Point:
def __init__(self, x = 0, y= 0):
self.x = x
self.y = y
def __str__(self):
return "(%d, %d)" % (self.x, self.y)
def fun1(point):
point.x = point.x + 3
point.y = point.y + 3
time.sleep(1)
return point
def fun2(x):
time.sleep(1)
logging.info(time.ctime() + ", fun2 input x:" + str(x))
return x * x
if __name__ == '__main__':
pool = Pool(4)
#test1
mylist = [x for x in range(10)]
ret = pool.map(fun2, mylist)
print ret
#test2
mydata = [Point(x, y) for x in range(3) for y in range(2)]
res = pool.map(fun1, mydata)
for i in res:
print str(i)
#end
pool.close()
pool.join()
print "end"
運行結(jié)果:
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
(3, 3)
(3, 4)
(4, 3)
(4, 4)
(5, 3)
(5, 4)
end
4. 參考
Python 多進程 multiprocessing.Pool類詳解
Python 多線程和多進程編程總結(jié)
Python的全局鎖問題
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python進程與線程操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》、《Python+MySQL數(shù)據(jù)庫程序設(shè)計入門教程》及《Python常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
Pytorch 如何訓(xùn)練網(wǎng)絡(luò)時調(diào)整學(xué)習(xí)率
這篇文章主要介紹了Pytorch 如何訓(xùn)練網(wǎng)絡(luò)時調(diào)整學(xué)習(xí)率的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05
python 求1-100之間的奇數(shù)或者偶數(shù)之和的實例
今天小編就為大家分享一篇python 求1-100之間的奇數(shù)或者偶數(shù)之和的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06

