千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python中使用多進(jìn)程

Python中使用多進(jìn)程

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-06 16:59:06 1699261146

python中multiprocessing模塊就是跨平臺(tái)版本的多進(jìn)程模塊,提供了一個(gè)Process類來(lái)代表一個(gè)進(jìn)程對(duì)象,這個(gè)對(duì)象可以理解為是一個(gè)獨(dú)立的進(jìn)程,可以執(zhí)行另外的事情

示例1

frommultiprocessingimportProcess

importtime

defrun_process():

whileTrue:

print("子進(jìn)程----2----")

time.sleep(1)

if__name__=='__main__':

p=Process(target=run_process)#target指定目標(biāo)函數(shù)

p.start()

whileTrue:

print("主進(jìn)程----1----")

time.sleep(1)

Process語(yǔ)法:

Process([group[,target[,name[,args[,kwargs]]]]])

參數(shù)--------------------------

target:如果傳遞了函數(shù)的引用,可以任務(wù)這個(gè)子進(jìn)程就執(zhí)行這里的代碼

args:給target指定的函數(shù)傳遞的參數(shù),以元組的方式傳遞

kwargs:給target指定的函數(shù)傳遞命名參數(shù)

name:給進(jìn)程設(shè)定一個(gè)名字,可以不設(shè)定

group:指定進(jìn)程組,大多數(shù)情況下用不到

Process創(chuàng)建的實(shí)例對(duì)象的常用方法:

方法--------------------------

start():?jiǎn)?dòng)子進(jìn)程實(shí)例(創(chuàng)建子進(jìn)程)

is_alive():判斷進(jìn)程子進(jìn)程是否還在活著

join([timeout]):是否等待子進(jìn)程執(zhí)行結(jié)束,或等待多少秒

terminate():不管任務(wù)是否完成,立即終止子進(jìn)程

Process創(chuàng)建的實(shí)例對(duì)象的常用屬性:

屬性-------------------------

name:當(dāng)前進(jìn)程的別名,默認(rèn)為Process-N,N為從1開(kāi)始遞增的整數(shù)

pid:當(dāng)前進(jìn)程的pid(進(jìn)程號(hào))

示例2進(jìn)程pid

frommultiprocessingimportProcess

importtime

importos

defrun_process():

whileTrue:

print("子進(jìn)程----pid:{}----".format(os.getpid()))

print()

time.sleep(1)

if__name__=='__main__':

p=Process(target=run_process)

p.start()

whileTrue:

print("主進(jìn)程----pid:{}----".format(os.getpid()))

time.sleep(1)

示例3子進(jìn)程目標(biāo)方法傳參

frommultiprocessingimportProcess

importtime

importos

defrun_process(course,teacher,*args,**kwargs):

whileTrue:

print("子進(jìn)程----pid:{}----{}上{}課".format(os.getpid(),teacher,course))

print()

time.sleep(1)

if__name__=='__main__':

p=Process(target=run_process,args=('語(yǔ)文',),kwargs={'teacher':'張三'})

p.start()

whileTrue:

print("主進(jìn)程----pid:{}----{}上{}課".format(os.getpid(),'李四','數(shù)學(xué)'))

time.sleep(1)

示例4進(jìn)程間不會(huì)共享全局變量

frommultiprocessingimportProcess

importtime

importos

num_list=[0,1,3,4,5,6,7,8,9,10]

i=3

defrun_process1():

globali

whilei:

print("子進(jìn)程----pid:{}----".format(os.getpid()))

num_list.pop()

print(num_list)

i=i-1

time.sleep(1)

defrun_process2():

globali

whilei:

print("子進(jìn)程----pid:{}----".format(os.getpid()))

num_list.append(i+1)

print(num_list)

i=i-1

time.sleep(1)

if__name__=='__main__':

p=Process(target=run_process1)

p.start()

p=Process(target=run_process2)

p.start()

輸出

子進(jìn)程----pid:10187----

[0,1,3,4,5,6,7,8,9]

子進(jìn)程----pid:10188----

[0,1,3,4,5,6,7,8,9,10,4]

子進(jìn)程----pid:10187----

[0,1,3,4,5,6,7,8]

子進(jìn)程----pid:10188----

[0,1,3,4,5,6,7,8,9,10,4,3]

子進(jìn)程----pid:10187----

[0,1,3,4,5,6,7]

子進(jìn)程----pid:10188----

[0,1,3,4,5,6,7,8,9,10,4,3,2]

以上內(nèi)容為大家介紹了Python中使用多進(jìn)程,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.madgrindclothing.com/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
Python 中少為人知的十個(gè)安全陷阱!

Python開(kāi)發(fā)者們?cè)谑褂脴?biāo)準(zhǔn)庫(kù)和通用框架時(shí),都以為自己的程序具有可靠的安全性。然而,在Python中,就像在任何其它編程語(yǔ)言中一樣,有一些特性可...詳情>>

2023-11-06 19:59:06
python修改列表元素有什么方法

增刪改查是處理數(shù)據(jù)最常見(jiàn)的方法,前兩種說(shuō)過(guò)了,這里就要說(shuō)說(shuō)python提供的兩種修改列表元素的方法,一種是修改單個(gè)元素,還有一種的修改一組數(shù)...詳情>>

2023-11-06 18:29:06
為什么企業(yè)很難招聘到好的python程序員?

原因有很多,其中幾個(gè)主要原因如下:1、被人敬仰的大牛級(jí)python工程師門大都被大型的互聯(lián)網(wǎng)公司收了,并有著自己所需要的一切資源,正安穩(wěn)過(guò)活...詳情>>

2023-11-06 18:25:30
python之內(nèi)建函數(shù)的方法

內(nèi)建函數(shù)和方法(built-infunctionsandmethods)根據(jù)定義,內(nèi)建的(built-in)模塊是指使用C寫(xiě)的模塊,可以通過(guò)sys模塊的builtin_module_names字段...詳情>>

2023-11-06 18:03:54
python作為一種編程語(yǔ)言有多強(qiáng)大?

說(shuō)實(shí)話,Python是一門強(qiáng)大的語(yǔ)言,幾乎所有東西都可以用Python創(chuàng)建!這就是為什么它被YouTube,Instagram,Netflix甚至Quora使用的原因!這門編程...詳情>>

2023-11-06 17:53:06