python多進程取代多線程的探究
1、說明
可以使用多核CPU的多進程。
利用多進程,我們并行地運行一些python解釋器,每個進程都有自己的私有空間,有自己的GIL,而且每個進程都是串行的,因此GIL之間不存在競爭。
所以GIL沒有任何問題。Python提供了一個multiprocessing模塊,使我們可以很容易地創建流程。
2、實例
importtime
frommultiprocessingimportPool
COUNT=10000000
start=time.clock()
defcountdown(n):
whilen>0:
n-=1
pool=Pool(processes=2)
start=time.clock()
r1=pool.apply_async(countdown,[COUNT//2])
r2=pool.apply_async(countdown,[COUNT//2])
pool.close()
pool.join()
print('Timeused:',time.clock()-start)
#('Timeused:',0.0017779999999998353)
以上就是python多進程取代多線程的探究,希望能對大家有所幫助。如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。