本篇文章給大家分享的是有關如何在python中使用Process模塊,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

站在用戶的角度思考問題,與客戶深入溝通,找到甘肅網(wǎng)站設計與甘肅網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設計與互聯(lián)網(wǎng)技術結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設計、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、雅安服務器托管、企業(yè)郵箱。業(yè)務覆蓋甘肅地區(qū)。
1、簡單易用,與C/C++、Java、C# 等傳統(tǒng)語言相比,Python對代碼格式的要求沒有那么嚴格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺上使用;3、Python面向?qū)ο螅軌蛑С置嫦蜻^程編程,也支持面向?qū)ο缶幊蹋?、Python是一種解釋性語言,Python寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序;5、Python功能強大,擁有的模塊眾多,基本能夠?qū)崿F(xiàn)所有的常見功能。
進程Process是對各種資源管理的集合,包含對各種資源的調(diào)用、內(nèi)存的管理、網(wǎng)絡接口的調(diào)用;一個進程Process可以包含多個子進程,啟動一個進程的時候會自動創(chuàng)建一個線程,進程里的第一個線程就是主線程(即python __name__ == ‘__main__’);
對于線程操作可以用threading模塊,那么對于進程的創(chuàng)建python同樣也提供了Process模塊,創(chuàng)建進程時需要導入該模塊,語法如下:
1 2 3 4 5 | # 導入進程模塊 frommultiprocessingimportProcess
# 創(chuàng)建進程 p=Process(group=None,target=None,name=None,args=(),kwargs={}) |
參數(shù)介紹:
group — 參數(shù)未使用,默認值為None;
target — 表示調(diào)用對象,即子進程要執(zhí)行的任務(函數(shù)名字);
args — 子進程對應函數(shù)的參數(shù),并且類型是元組tuple;
kwargs — 子進程對應函數(shù)的參數(shù),并且類型是字典dict,如kwargs = {‘name’:Jack, ‘a(chǎn)ge’:18};
name — 子進程名稱;
返回值:返回進程實例對象;
其實進程Process的函數(shù)和線程threading類似,具體如下:
1.start() — 啟動進程;
2.terminate() — 強制終止進程,不會進行任何清理操作。如果該進程終止前,創(chuàng)建了子進程,那么該子進程在其強制結(jié)束后變?yōu)榻┦M程;如果該進程還保存了一個鎖那么也將不會被釋放,進而導致死鎖,使用時,要注意;
3.is_alive() — 判斷某進程是否存活,存活返回True,否則False;
4.join([timeout]) — 主線程等待子線程終止。timeout為可選擇超時時間;需要強調(diào)的是,p.join只能join住start開啟的進程,而不能join住run開啟的進程 ;
5.daemon — 默認值為False,如果設置為True,代表該進程為后臺守護進程;當該進程的父進程終止時,該進程也隨之終止;并且設置為True后,該進程不能創(chuàng)建子進程,設置該屬性必須在start()之前;
6.name — 進程名稱;
7.pid— 進程ID標識,pid,值得注意的是:如果在start函數(shù)之前獲取pid默認為None,因為進程還未創(chuàng)建,獲取不到pid;
8.exitcode — 進程運行時為None,如果為-N,表示被信號N結(jié)束了;
9.authkey — 進程身份驗證,默認是由os.urandom()隨機生成32字符的字符串。這個鍵的用途是設計涉及網(wǎng)絡連接的底層進程間的通信提供安全性,這類連接只有在具有相同身份驗證才能成功;
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(個人博客地址): shuopython.com @WeChat Official Account(微信公眾號):猿說python @Github:www.github.com
@File:python_process.py @Time:2019/12/21 21:25
@Motto:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅持不懈地積累! """
frommultiprocessingimportProcess
defpeople_info(*args,**kwargs): print(args,kwargs)
defmain():
# 信息列表 list_info=[{"name":"zhangsan","height":"175cm"}, {"name":"lisi","height":"155cm"}, {"name":"wangwu","height":"195cm"}, {"name":"liqi","height":"166cm"}, {"name":"wangba","height":"125cm"},]
# 創(chuàng)建進程 foriinrange(5): p=Process(target=people_info,args=(i,),kwargs=list_info[i]) # 設置為守護進程,必須設置在start函數(shù)之前,否則會產(chǎn)生異常 # 默認為False,即主進程會等待子進程結(jié)束之后才結(jié)束, # 如果設置為True,主進程結(jié)束之后所有的子進程自動結(jié)束,不管子進程是否已經(jīng)執(zhí)行完所有任務 # p.daemon = True
# 啟動進程 p.start()
# 獲取進程pid,如果在start函數(shù)之前獲取pid,默認為None,因為進程還沒啟動 print("進程process pid = ",p.pid) # 獲取進程名字 print("進程process name = ",p.name) # 獲取進程pid print("進程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 | 進程processpid= 2600 進程processname= Process-1 進程processexitcode= None 進程processpid= 4372 進程processname= Process-2 進程processexitcode= None 進程processpid= 14124 進程processname= Process-3 進程processexitcode= None 進程processpid= 10920 進程processname= Process-4 進程processexitcode= None 進程processpid= 4892 進程processname= Process-5 進程processexitcode= 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)建子進程 os.getpid() 獲取自身ID os.getppid() 獲取父進程ID |
以上就是如何在python中使用Process模塊,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁名稱:如何在python中使用Process模塊
文章鏈接:http://chinadenli.net/article28/pphpjp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、品牌網(wǎng)站設計、自適應網(wǎng)站、網(wǎng)站導航、全網(wǎng)營銷推廣、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)