您好,登錄后才能下訂單哦!
進(jìn)程(Process)是計(jì)算機(jī)中的程序關(guān)于某數(shù)據(jù)集合上的一次運(yùn)行活動(dòng),是系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位,是操作系統(tǒng)結(jié)構(gòu)的基礎(chǔ)。在早期面向進(jìn)程設(shè)計(jì)的計(jì)算機(jī)結(jié)構(gòu)中,進(jìn)程是程序的基本執(zhí)行實(shí)體;在當(dāng)代面向線程設(shè)計(jì)的計(jì)算機(jī)結(jié)構(gòu)中,進(jìn)程是線程的容器。程序是指令、數(shù)據(jù)及其組織形式的描述,進(jìn)程是程序的實(shí)體。
對(duì)于線程操作可以用threading模塊,那么對(duì)于進(jìn)程的創(chuàng)建python同樣也提供了Process模塊,創(chuàng)建進(jìn)程時(shí)需要導(dǎo)入該模塊,語法如下:
1 2 3 4 5 | # 導(dǎo)入進(jìn)程模塊 from multiprocessing import Process
# 創(chuàng)建進(jìn)程 p = Process(group=None, target=None, name=None, args=(), kwargs={}) |
參數(shù)介紹:
group — 參數(shù)未使用,默認(rèn)值為None;
target — 表示調(diào)用對(duì)象,即子進(jìn)程要執(zhí)行的任務(wù)(函數(shù)名字);
args — 子進(jìn)程對(duì)應(yīng)函數(shù)的參數(shù),并且類型是元組tuple;
kwargs — 子進(jìn)程對(duì)應(yīng)函數(shù)的參數(shù),并且類型是字典dict,如kwargs = {‘name’:Jack, ‘a(chǎn)ge’:18};
name — 子進(jìn)程名稱;
返回值:返回進(jìn)程實(shí)例對(duì)象;
其實(shí)進(jìn)程Process的函數(shù)和線程threading類似,具體如下:
1.start() — 啟動(dòng)進(jìn)程;
2.terminate() — 強(qiáng)制終止進(jìn)程,不會(huì)進(jìn)行任何清理操作。如果該進(jìn)程終止前,創(chuàng)建了子進(jìn)程,那么該子進(jìn)程在其強(qiáng)制結(jié)束后變?yōu)榻┦M(jìn)程;如果該進(jìn)程還保存了一個(gè)鎖那么也將不會(huì)被釋放,進(jìn)而導(dǎo)致死鎖,使用時(shí),要注意;
3.is_alive() — 判斷某進(jìn)程是否存活,存活返回True,否則False;
4.join([timeout]) — 主線程等待子線程終止。timeout為可選擇超時(shí)時(shí)間;需要強(qiáng)調(diào)的是,p.join只能join住start開啟的進(jìn)程,而不能join住run開啟的進(jìn)程 ;
5.daemon — 默認(rèn)值為False,如果設(shè)置為True,代表該進(jìn)程為后臺(tái)守護(hù)進(jìn)程;當(dāng)該進(jìn)程的父進(jìn)程終止時(shí),該進(jìn)程也隨之終止;并且設(shè)置為True后,該進(jìn)程不能創(chuàng)建子進(jìn)程,設(shè)置該屬性必須在start()之前;
6.name — 進(jìn)程名稱;
7.pid— 進(jìn)程ID標(biāo)識(shí),pid,值得注意的是:如果在start函數(shù)之前獲取pid默認(rèn)為None,因?yàn)檫M(jìn)程還未創(chuàng)建,獲取不到pid;
8.exitcode — 進(jìn)程運(yùn)行時(shí)為None,如果為-N,表示被信號(hào)N結(jié)束了;
9.authkey — 進(jìn)程身份驗(yàn)證,默認(rèn)是由os.urandom()隨機(jī)生成32字符的字符串。這個(gè)鍵的用途是設(shè)計(jì)涉及網(wǎng)絡(luò)連接的底層進(jìn)程間的通信提供安全性,這類連接只有在具有相同身份驗(yàn)證才能成功;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | # !usr/bin/env python # -*- coding:utf-8 _*- """ @Author:何以解憂 @Blog(個(gè)人博客地址): shuopython.com @WeChat Official Account(微信公眾號(hào)):猿說python @Github:www.github.com
@File:python_process.py @Time:2019/12/21 21:25
@Motto:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅(jiān)持不懈地積累! """
from multiprocessing import Process
def people_info(*args,**kwargs): print(args,kwargs)
def main():
# 信息列表 list_info = [{"name":"zhangsan","height":"175cm"}, {"name": "lisi", "height": "155cm"}, {"name": "wangwu", "height": "195cm"}, {"name": "liqi", "height": "166cm"}, {"name": "wangba", "height": "125cm"},]
# 創(chuàng)建進(jìn)程 for i in range(5): p = Process(target=people_info,args=(i,),kwargs=list_info[i]) # 設(shè)置為守護(hù)進(jìn)程,必須設(shè)置在start函數(shù)之前,否則會(huì)產(chǎn)生異常 # 默認(rèn)為False,即主進(jìn)程會(huì)等待子進(jìn)程結(jié)束之后才結(jié)束, # 如果設(shè)置為True,主進(jìn)程結(jié)束之后所有的子進(jìn)程自動(dòng)結(jié)束,不管子進(jìn)程是否已經(jīng)執(zhí)行完所有任務(wù) # p.daemon = True
# 啟動(dòng)進(jìn)程 p.start()
# 獲取進(jìn)程pid,如果在start函數(shù)之前獲取pid,默認(rèn)為None,因?yàn)檫M(jìn)程還沒啟動(dòng) print("進(jìn)程process pid = ",p.pid) # 獲取進(jìn)程名字 print("進(jìn)程process name = ",p.name) # 獲取進(jìn)程pid print("進(jìn)程process exitcode = ",p.exitcode)
if __name__ == "__main__": main() |
輸出結(jié)果:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | 進(jìn)程process pid = 2600 進(jìn)程process name = Process-1 進(jìn)程process exitcode = None 進(jìn)程process pid = 4372 進(jìn)程process name = Process-2 進(jìn)程process exitcode = None 進(jìn)程process pid = 14124 進(jìn)程process name = Process-3 進(jìn)程process exitcode = None 進(jìn)程process pid = 10920 進(jìn)程process name = Process-4 進(jìn)程process exitcode = None 進(jìn)程process pid = 4892 進(jìn)程process name = Process-5 進(jìn)程process exitcode = None (0,) {'name': 'zhangsan', 'height': '175cm'} (1,) {'name': 'lisi', 'height': '155cm'} (2,) {'name': 'wangwu', 'height': '195cm'} (3,) {'name': 'liqi', 'height': '166cm'} (4,) {'name': 'wangba', 'height': '125cm'} |
Python 的 os
模塊封裝了常見的系統(tǒng)調(diào)用,其中就包括:
1 2 3 | os.fork() 創(chuàng)建子進(jìn)程 os.getpid() 獲取自身 ID os.getppid() 獲取父進(jìn)程 ID |
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。