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

在?Python?中利用Pool?進(jìn)行多處理

 更新時(shí)間:2022年04月24日 11:52:37   作者:宇宙之一粟  
這篇文章主要介紹了在?Python?中利用Pool進(jìn)行多處理,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下

為什么要引入線程池

如果在程序中經(jīng)常要用到線程,頻繁的創(chuàng)建和銷(xiāo)毀線程會(huì)浪費(fèi)很多硬件資源,
所以需要把線程和任務(wù)分離。線程可以反復(fù)利用,省去了重復(fù)創(chuàng)建的麻煩。
在 Process 類(lèi)中,我們必須顯式地創(chuàng)建流程。但是,Pool 類(lèi)更方便,您不必手動(dòng)管理它。創(chuàng)建池對(duì)象的語(yǔ)法是 ?multiprocessing.Pool(processes, initializer, initargs, maxtasksperchild, context)?? 。所有參數(shù)都是可選的。

  • processes 表示您要?jiǎng)?chuàng)建的工作進(jìn)程的數(shù)量。默認(rèn)值通過(guò) os.cpu_count() 獲取。
  • initializer第二個(gè)初始化器參數(shù)是一個(gè)用于初始化的函數(shù)。
  • initargs 是傳遞給它的參數(shù)。
  • maxtasksperchild 表示分配給每個(gè)子進(jìn)程的任務(wù)數(shù)。在完成該數(shù)量的任務(wù)之后,該進(jìn)程將被一個(gè)新的工作進(jìn)程替換。指定它的好處是任何未使用的資源都將被釋放。如果未提供任何內(nèi)容,則只要池存在,進(jìn)程就會(huì)存在。
import time
from multiprocessing import Pool


def square(x):
print(f"start process:{x}")
square = x * x
print(f"square {x}:{square}")
time.sleep(1)
print(f"end process:{x}")


if __name__ == "__main__":
starttime = time.time()
pool = Pool()
pool.map(square, range(0, 5))
pool.close()
endtime = time.time()
print(f"Time taken {endtime-starttime} seconds")

結(jié)果為:

start process:0
start process:1
square 1:1
square 0:0
end process:1
start process:2
end process:0
start process:3
square 2:4
square 3:9
end process:3
end process:2
start process:4
square 4:16
end process:4
Time taken 3.0474610328674316 seconds

在這里,我們從多處理模塊中導(dǎo)入 Pool 類(lèi)。在主函數(shù)中,我們創(chuàng)建了一個(gè) Pool 類(lèi)的對(duì)象。 pool.map() 將我們想要并行化的函數(shù)和一個(gè)可迭代的函數(shù)作為參數(shù)。它在可迭代的每個(gè)項(xiàng)目上運(yùn)行給定的函數(shù)。它還接受一個(gè)可選的 chunksize 參數(shù),它將可迭代對(duì)象拆分為等于給定大小的塊,并將每個(gè)塊作為單獨(dú)的任務(wù)傳遞。 pool.close() 用于拒絕新任務(wù)。
我們可以看到花費(fèi)的時(shí)間大約是 3 秒。
?pool.imap()?? 與 ?pool.map()?? 方法幾乎相同。不同的是,每個(gè)項(xiàng)目的結(jié)果都是在準(zhǔn)備好后立即收到的,而不是等待所有項(xiàng)目都完成。此外, ?map()?? 方法將可迭代對(duì)象轉(zhuǎn)換為列表(如果不是)。但是, ?imap()?? 方法沒(méi)有。

來(lái)看下一個(gè)例子:

import time
from multiprocessing import Pool


def square(x):
print(f"start process {x}")
square = x * x
time.sleep(1)
print(f"end process {x}")
return square


if __name__ == "__main__":
pool = Pool()
a = pool.map(square, range(0, 5))
print(a)

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

start process 0
start process 1
end process 0
start process 2
end process 1
start process 3
end process 2
start process 4
end process 3
end process 4
[0, 1, 4, 9, 16]

from concurrent.futures import ThreadPoolExecutor

def say_hello():
print("Hello")

executor = ThreadPoolExecutor(50)
for i in range(0, 10):
executor.submit(say_hello)

練習(xí)

利用 Python 多線程模擬商品秒殺過(guò)程,不可以出現(xiàn)超買(mǎi)和超賣(mài)的情況。假設(shè)A商品有50件參與秒殺活動(dòng),10分鐘秒殺自動(dòng)結(jié)束。

  • kill_total 商品總數(shù)
  • kill_num 成功搶購(gòu)數(shù)
  • kill_flag 有效標(biāo)志位
  • kill_user 成功搶購(gòu)的用戶(hù)ID
from redis_db import pool
import redis
import random
from concurrent.futures import ThreadPoolExecutor

s = set()
while True:
if len(s) == 1000:
break
num = random.randint(10000, 100000)
s.add(num)
print(s)

con = redis.Redis(
connection_pool=pool
)

try:
con.delete("kill_total", "kill_num", "kill_flag", "kill_user")
con.set("kill_total", 50)
con.set("kill_num", 0)
con.set("kill_flag", 1)
con.expire("kill_flag", 600)

except Exception as e:
print(e)
finally:
del con

executor = ThreadPoolExecutor(200)
def buy():
connection = redis.Redis(
connection_pool=pool
)
pipline = connection.pipline()
try:
if connection.exists("kill_flag") == 1:
pipline.watch("kill_num", "kill_user")
total = pipline.get("kill_total")
num = int(pipline.get("kill_num").decode("utf-8"))
if num < total:
pipline.multi()
pipline.incr("kill_num")
user_id = s.pop()
pipline.rpush("kill_user", user_id)

pipline.execute()
except Exception as e:
print(e)
finally:
if "pipline" in dir():
pipline.reset()
del connection

for i in range(0, 1000):
executor.submit(buy)
print("秒殺活動(dòng)已經(jīng)結(jié)束")

到此這篇關(guān)于在 Python 中利用Pool 進(jìn)行多處理的文章就介紹到這了,更多相關(guān) Python Pool 多處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • pytorch框架的詳細(xì)介紹與應(yīng)用詳解

    pytorch框架的詳細(xì)介紹與應(yīng)用詳解

    這篇文章主要介紹了pytorch框架的詳細(xì)介紹與應(yīng)用,Torch?是一個(gè)經(jīng)典的對(duì)多維矩陣數(shù)據(jù)進(jìn)行操作的張量(tensor?)庫(kù),在機(jī)器學(xué)習(xí)和其他數(shù)學(xué)密集型應(yīng)用有廣泛應(yīng)用,本文給大家詳細(xì)講解,需要的朋友可以參考下
    2023-04-04
  • Python還能這么玩之只用30行代碼從excel提取個(gè)人值班表

    Python還能這么玩之只用30行代碼從excel提取個(gè)人值班表

    公司實(shí)行項(xiàng)目值班制度,拿到值班表,看到全部的值班信息,要去查找自己的值班信息,是一件頭痛的事情.作為程序員,當(dāng)然要簡(jiǎn)化,將自己的信息提煉出來(lái),需要的朋友可以參考下
    2021-06-06
  • pandas的qcut()方法詳解

    pandas的qcut()方法詳解

    這篇文章主要介紹了pandas的qcut()方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 如何用Matplotlib 畫(huà)三維圖的示例代碼

    如何用Matplotlib 畫(huà)三維圖的示例代碼

    這篇文章主要介紹了如何用Matplotlib 畫(huà)三維圖的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 如何真正的了解python裝飾器

    如何真正的了解python裝飾器

    在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于如何真正的了解python裝飾器的相關(guān)文章,需要的朋友們可以參考下。
    2020-08-08
  • Python Matplotlib 基于networkx畫(huà)關(guān)系網(wǎng)絡(luò)圖

    Python Matplotlib 基于networkx畫(huà)關(guān)系網(wǎng)絡(luò)圖

    這篇文章主要介紹了Python Matplotlib 基于networkx畫(huà)關(guān)系網(wǎng)絡(luò)圖,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • PyQt5實(shí)現(xiàn)登錄頁(yè)面

    PyQt5實(shí)現(xiàn)登錄頁(yè)面

    這篇文章主要為大家詳細(xì)介紹了PyQt5實(shí)現(xiàn)登錄頁(yè)面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • python標(biāo)記語(yǔ)句塊使用方法總結(jié)

    python標(biāo)記語(yǔ)句塊使用方法總結(jié)

    在本篇文章里小編給大家整理了關(guān)于python標(biāo)記語(yǔ)句塊使用方法以及相關(guān)知識(shí)點(diǎn),需要的朋友們參考下。
    2019-08-08
  • Pandas替換NaN值的方法實(shí)現(xiàn)

    Pandas替換NaN值的方法實(shí)現(xiàn)

    本文主要介紹了Pandas替換NaN值的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • django為Form生成的label標(biāo)簽添加class方式

    django為Form生成的label標(biāo)簽添加class方式

    這篇文章主要介紹了django為Form生成的label標(biāo)簽添加class方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05

最新評(píng)論