python中的多進(jìn)程的創(chuàng)建與啟動方式
python中的并發(fā)有三種形式,多進(jìn)程、多線程、協(xié)程。執(zhí)?并發(fā)任務(wù)的?的是為了提?程序運(yùn)?的效率。
一、多進(jìn)程的創(chuàng)建:多進(jìn)程的創(chuàng)建方法有兩種:
1、通過Process創(chuàng)建多進(jìn)程 Process語法結(jié)構(gòu):
Process(group, target, name, args, kwargs) group:指定進(jìn)程組,?多數(shù)情況下?不到 target:表示調(diào)用對象,即子進(jìn)程要執(zhí)行的任務(wù) name:子進(jìn)程的名稱,可以不設(shè)定 args:給target指定的函數(shù)傳遞的參數(shù),以元組的?式傳遞 kwargs:給target指定的函數(shù)傳遞命名參數(shù)
Process常用方法:
p.start() 啟動進(jìn)程,并調(diào)用該子進(jìn)程中的p.run()方法 p.join(timeout):主進(jìn)程等待?進(jìn)程執(zhí)?結(jié)束再結(jié)束,timeout是可選的超時時間 is_alive():判斷進(jìn)程?進(jìn)程是否還存活 p.run() 進(jìn)程啟動時運(yùn)行的方法,正是它去調(diào)用target指定的函數(shù) p.terminate() ?即終??進(jìn)程
(1)首先,定義一個待調(diào)用的函數(shù):
import os from multiprocessing import Process def add(name,num): nums = 0 for i in range(num+1): nums = nums+i print("用戶%s:\n 相加結(jié)果為:%s \n 當(dāng)前進(jìn)程id為:%s \n 當(dāng)前子進(jìn)程的父進(jìn)程id: %s"%(name,nums,os.getpid(),os.getppid()))
(2)創(chuàng)建并啟動一個進(jìn)程
def test1(): '''啟動一個進(jìn)程調(diào)用''' name= '王五' p = Process(target=add,args=(name,10,)) p.start() p.join()
其中,p.join()方法可以讓主進(jìn)程等待子進(jìn)程結(jié)束之后再結(jié)束,如果不加這個方法,主進(jìn)程結(jié)束,子進(jìn)程還沒有結(jié)束。
(2)創(chuàng)建并啟動多個進(jìn)程
def test3(): names = ['王五','趙六','王麻子'] process_list=[] for name in names: p = Process(target=add,args=(name,10,)) p.start() process_list.append(p) for j in process_list: j.join()
2、通過進(jìn)程池創(chuàng)建并啟動多進(jìn)程
進(jìn)程池可以提供指定數(shù)量的進(jìn)程給用戶使用,即當(dāng)有新的請求提交到進(jìn)程池中時,如果池未滿,則會創(chuàng)建一個新的進(jìn)程用來執(zhí)行該請求;反之,如果池中的進(jìn)程數(shù)已經(jīng)達(dá)到規(guī)定最大值,那么該請求就會等待,只要池中有進(jìn)程空閑下來,該請求就能得到執(zhí)行。
Pool(numprocess, initializer, initargs)
numprocess 是要創(chuàng)建的進(jìn)程數(shù)。如果省略此參數(shù),默認(rèn)為cpu的最大核心數(shù)。
Initializer是每個工作進(jìn)程啟動時要執(zhí)行的可調(diào)用對象。
Initargs 傳遞給 initializer 的參數(shù)元祖,默認(rèn)為 None
def test4(): from multiprocessing import Pool '''啟動多個進(jìn)程2:進(jìn)程池''' p = Pool(5) names = ['王五','趙六','王麻子'] for name in names: p.apply_async(add,args=(name,10)) p.close() p.join()
3、通過繼承的方法創(chuàng)建多進(jìn)程
(1)首先創(chuàng)建一個進(jìn)程
class SubProcess(Process): def __init__(self,name,number): super(SubProcess, self).__init__() self.name = name self.number = number def run(self): sums = 0 for i in range(self.number): sums = sums+i print("用戶%s:\n 相加結(jié)果為:%s \n 當(dāng)前進(jìn)程id為:%s \n 當(dāng)前子進(jìn)程的父進(jìn)程id: %s"\ %(self.name,self.number,os.getpid(),os.getppid()))
(2)啟動一個進(jìn)程
def call_Sub0(): '''啟動一個進(jìn)程調(diào)用''' name = '張三' p = SubProcess(name,10) p.start() p.join()
(3)通過列表啟動多個進(jìn)程
def call_Sub1(): '''啟動多個進(jìn)程1''' names = ['王五','趙六','王麻子'] process_list=[] for name in names: p = SubProcess(name,10) p.start() process_list.append(p) for j in process_list: j.join() if __name__ == '__main__': print("當(dāng)前主進(jìn)程id:",os.getpid()) call_Sub1() print("計算結(jié)束!")
4、進(jìn)程創(chuàng)建與啟動完整代碼
import os from multiprocessing import Process def add(name,num): nums = 0 for i in range(num+1): nums = nums+i print("用戶%s:\n 相加結(jié)果為:%s \n 當(dāng)前進(jìn)程id為:%s \n 當(dāng)前子進(jìn)程的父進(jìn)程id: %s"%(name,nums,os.getpid(),os.getppid())) def test1(): '''啟動一個進(jìn)程調(diào)用''' name= '王五' p = Process(target=add,args=(name,10,)) p.start() p.join() def test3(): '''啟動多個進(jìn)程2''' names = ['王五','趙六','王麻子'] process_list=[] for name in names: p = Process(target=add,args=(name,10,)) p.start() process_list.append(p) for j in process_list: j.join() ''' 進(jìn)程池:可以提供指定數(shù)量的進(jìn)程給用戶使用,即當(dāng)有新的請求提交到進(jìn)程池中時, 如果池未滿,則會創(chuàng)建一個新的進(jìn)程用來執(zhí)行該請求;反之,如果池中的進(jìn)程數(shù)已經(jīng)達(dá)到規(guī)定最大值, 那么該請求就會等待,只要池中有進(jìn)程空閑下來,該請求就能得到執(zhí)行。 ''' def test4(): from multiprocessing import Pool '''啟動多個進(jìn)程2:進(jìn)程池''' p = Pool(5) names = ['王五','趙六','王麻子'] for name in names: p.apply_async(add,args=(name,10)) p.close() p.join() class SubProcess(Process): def __init__(self,name,number): super(SubProcess, self).__init__() self.name = name self.number = number def run(self): sums = 0 for i in range(self.number): sums = sums+i print("用戶%s:\n 相加結(jié)果為:%s \n 當(dāng)前進(jìn)程id為:%s \n 當(dāng)前子進(jìn)程的父進(jìn)程id: %s"\ %(self.name,self.number,os.getpid(),os.getppid())) def call_Sub0(): '''啟動一個進(jìn)程調(diào)用''' name = '張三' p = SubProcess(name,10) p.start() p.join() def call_Sub1(): '''啟動多個進(jìn)程1''' names = ['王五','趙六','王麻子'] process_list=[] for name in names: p = SubProcess(name,10) p.start() process_list.append(p) for j in process_list: j.join() if __name__ == '__main__': print("當(dāng)前主進(jìn)程id:",os.getpid()) call_Sub1() print("計算結(jié)束!")
到此這篇關(guān)于python中的多進(jìn)程的創(chuàng)建與啟動的文章就介紹到這了,更多相關(guān)python多進(jìn)程創(chuàng)建與啟動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python列表list操作符實例分析【標(biāo)準(zhǔn)類型操作符、切片、連接字符、列表解析、重復(fù)操作等】
這篇文章主要介紹了Python列表list操作符,結(jié)合實例形式分析了標(biāo)準(zhǔn)類型操作符、切片、連接字符、列表解析、重復(fù)操作等使用技巧,需要的朋友可以參考下2017-07-07python pywinauto使用過程及問題小結(jié)
在pywinauto庫中,uia即UIAutomation,是微軟提供的用于用戶界面自動化測試和輔助功能訪問的技術(shù)框架,UIAutomation支持自動化腳本與各種UI元素交互,本文給大家介紹python pywinauto使用過程及問題小結(jié),感興趣的朋友一起看看吧2024-10-10詳解如何用django實現(xiàn)redirect的幾種方法總結(jié)
這篇文章主要介紹了如何用django實現(xiàn)redirect的幾種方法總結(jié),詳細(xì)的介紹3種實現(xiàn)方式,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Python讀取Excel數(shù)據(jù)實現(xiàn)批量生成PPT
我們常常面臨著大量的重復(fù)性工作,通過人工方式處理往往耗時耗力易出錯。而Python在辦公自動化方面具有天然優(yōu)勢。本文將利用讀取Excel數(shù)據(jù)并實現(xiàn)批量生成PPT,需要的可以參考一下2022-05-05