Python使用進程Process模塊管理資源
進程Process是對各種資源管理的集合,包含對各種資源的調(diào)用、內(nèi)存的管理、網(wǎng)絡(luò)接口的調(diào)用;一個進程Process可以包含多個子進程,啟動一個進程的時候會自動創(chuàng)建一個線程,進程里的第一個線程就是主線程(即python __name__ == ‘__main__');
進程Process模塊
對于線程操作可以用threading模塊,那么對于進程的創(chuàng)建python同樣也提供了Process模塊,創(chuàng)建進程時需要導(dǎo)入該模塊,語法如下:
# 導(dǎo)入進程模塊 from multiprocessing import Process # 創(chuàng)建進程 p = Process(group=None, target=None, name=None, args=(), kwargs={})
參數(shù)介紹:
group — 參數(shù)未使用,默認(rèn)值為None;
target — 表示調(diào)用對象,即子進程要執(zhí)行的任務(wù)(函數(shù)名字);
args — 子進程對應(yīng)函數(shù)的參數(shù),并且類型是元組tuple;
kwargs — 子進程對應(yīng)函數(shù)的參數(shù),并且類型是字典dict,如kwargs = {‘name':Jack, ‘a(chǎn)ge':18};
name — 子進程名稱;
返回值:返回進程實例對象;
三.進程Process函數(shù)介紹
其實進程Process的函數(shù)和線程threading類似,具體如下:
1.start() — 啟動進程;
2.terminate() — 強制終止進程,不會進行任何清理操作。如果該進程終止前,創(chuàng)建了子進程,那么該子進程在其強制結(jié)束后變?yōu)榻┦M程;如果該進程還保存了一個鎖那么也將不會被釋放,進而導(dǎo)致死鎖,使用時,要注意;
3.is_alive() — 判斷某進程是否存活,存活返回True,否則False;
4.join([timeout]) — 主線程等待子線程終止。timeout為可選擇超時時間;需要強調(diào)的是,p.join只能join住start開啟的進程,而不能join住run開啟的進程 ;
5.daemon — 默認(rèn)值為False,如果設(shè)置為True,代表該進程為后臺守護進程;當(dāng)該進程的父進程終止時,該進程也隨之終止;并且設(shè)置為True后,該進程不能創(chuàng)建子進程,設(shè)置該屬性必須在start()之前;
6.name — 進程名稱;
7.pid— 進程ID標(biāo)識,pid,值得注意的是:如果在start函數(shù)之前獲取pid默認(rèn)為None,因為進程還未創(chuàng)建,獲取不到pid;
8.exitcode — 進程運行時為None,如果為-N,表示被信號N結(jié)束了;
9.authkey — 進程身份驗證,默認(rèn)是由os.urandom()隨機生成32字符的字符串。這個鍵的用途是設(shè)計涉及網(wǎng)絡(luò)連接的底層進程間的通信提供安全性,這類連接只有在具有相同身份驗證才能成功;
進程Process使用
# !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:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅持不懈地積累! """ 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)建進程 for i in range(5): p = Process(target=people_info,args=(i,),kwargs=list_info[i]) # 設(shè)置為守護進程,必須設(shè)置在start函數(shù)之前,否則會產(chǎn)生異常 # 默認(rèn)為False,即主進程會等待子進程結(jié)束之后才結(jié)束, # 如果設(shè)置為True,主進程結(jié)束之后所有的子進程自動結(jié)束,不管子進程是否已經(jīng)執(zhí)行完所有任務(wù) # p.daemon = True # 啟動進程 p.start() # 獲取進程pid,如果在start函數(shù)之前獲取pid,默認(rèn)為None,因為進程還沒啟動 print("進程process pid = ",p.pid) # 獲取進程名字 print("進程process name = ",p.name) # 獲取進程pid print("進程process exitcode = ",p.exitcode) if __name__ == "__main__": main()
輸出結(jié)果:
進程process pid = 2600 進程process name = Process-1 進程process exitcode = None 進程process pid = 4372 進程process name = Process-2 進程process exitcode = None 進程process pid = 14124 進程process name = Process-3 進程process exitcode = None 進程process pid = 10920 進程process name = Process-4 進程process exitcode = None 進程process pid = 4892 進程process name = Process-5 進程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)用,其中就包括:
os.fork() 創(chuàng)建子進程
os.getpid() 獲取自身 ID
os.getppid() 獲取父進程 ID
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python中八種數(shù)據(jù)導(dǎo)入方法總結(jié)
數(shù)據(jù)分析過程中,需要對獲取到的數(shù)據(jù)進行分析,往往第一步就是導(dǎo)入數(shù)據(jù)。導(dǎo)入數(shù)據(jù)有很多方式,不同的數(shù)據(jù)文件需要用到不同的導(dǎo)入方式,相同的文件也會有幾種不同的導(dǎo)入方式。下面總結(jié)幾種常用的文件導(dǎo)入方法2022-11-11使用python快速在局域網(wǎng)內(nèi)搭建http傳輸文件服務(wù)的方法
這篇文章主要介紹了使用 python快速在局域網(wǎng)內(nèi)搭建http傳輸文件服務(wù),但是這種方法不要傳輸機密文件,安全性不高,只用到http協(xié)議沒有使用任何加密協(xié)議,具體實現(xiàn)方法跟隨小編一起看看吧2019-11-11判斷Threading.start新線程是否執(zhí)行完畢的實例
這篇文章主要介紹了判斷Threading.start新線程是否執(zhí)行完畢的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05解決在pycharm運行代碼,調(diào)用CMD窗口的命令運行顯示亂碼問題
今天小編就為大家分享一篇解決在pycharm運行代碼,調(diào)用CMD窗口的命令運行顯示亂碼問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08