久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

Python使用進(jìn)程Process模塊管理資源

瀏覽:5日期:2022-08-03 17:39:34

進(jìn)程Process是對各種資源管理的集合,包含對各種資源的調(diào)用、內(nèi)存的管理、網(wǎng)絡(luò)接口的調(diào)用;一個進(jìn)程Process可以包含多個子進(jìn)程,啟動一個進(jìn)程的時候會自動創(chuàng)建一個線程,進(jìn)程里的第一個線程就是主線程(即python __name__ == ‘__main__’);

進(jìn)程Process模塊

對于線程操作可以用threading模塊,那么對于進(jìn)程的創(chuàng)建python同樣也提供了Process模塊,創(chuàng)建進(jìn)程時需要導(dǎo)入該模塊,語法如下:

# 導(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)用對象,即子進(jìn)程要執(zhí)行的任務(wù)(函數(shù)名字);

args — 子進(jìn)程對應(yīng)函數(shù)的參數(shù),并且類型是元組tuple;

kwargs — 子進(jìn)程對應(yīng)函數(shù)的參數(shù),并且類型是字典dict,如kwargs = {‘name’:Jack, ‘a(chǎn)ge’:18};

name — 子進(jìn)程名稱;

返回值:返回進(jìn)程實例對象;

三.進(jìn)程Process函數(shù)介紹

其實進(jìn)程Process的函數(shù)和線程threading類似,具體如下:

1.start() — 啟動進(jìn)程;

2.terminate() — 強(qiáng)制終止進(jìn)程,不會進(jìn)行任何清理操作。如果該進(jìn)程終止前,創(chuàng)建了子進(jìn)程,那么該子進(jìn)程在其強(qiáng)制結(jié)束后變?yōu)榻┦M(jìn)程;如果該進(jìn)程還保存了一個鎖那么也將不會被釋放,進(jìn)而導(dǎo)致死鎖,使用時,要注意;

3.is_alive() — 判斷某進(jìn)程是否存活,存活返回True,否則False;

4.join([timeout]) — 主線程等待子線程終止。timeout為可選擇超時時間;需要強(qiáng)調(diào)的是,p.join只能join住start開啟的進(jìn)程,而不能join住run開啟的進(jìn)程 ;

5.daemon — 默認(rèn)值為False,如果設(shè)置為True,代表該進(jìn)程為后臺守護(hù)進(jìn)程;當(dāng)該進(jìn)程的父進(jìn)程終止時,該進(jìn)程也隨之終止;并且設(shè)置為True后,該進(jìn)程不能創(chuàng)建子進(jìn)程,設(shè)置該屬性必須在start()之前;

6.name — 進(jìn)程名稱;

7.pid— 進(jìn)程ID標(biāo)識,pid,值得注意的是:如果在start函數(shù)之前獲取pid默認(rèn)為None,因為進(jìn)程還未創(chuàng)建,獲取不到pid;

8.exitcode — 進(jìn)程運(yùn)行時為None,如果為-N,表示被信號N結(jié)束了;

9.authkey — 進(jìn)程身份驗證,默認(rèn)是由os.urandom()隨機(jī)生成32字符的字符串。這個鍵的用途是設(shè)計涉及網(wǎng)絡(luò)連接的底層進(jìn)程間的通信提供安全性,這類連接只有在具有相同身份驗證才能成功;

進(jìn)程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)建進(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ù)之前,否則會產(chǎn)生異常 # 默認(rèn)為False,即主進(jìn)程會等待子進(jìn)程結(jié)束之后才結(jié)束, # 如果設(shè)置為True,主進(jìn)程結(jié)束之后所有的子進(jìn)程自動結(jié)束,不管子進(jìn)程是否已經(jīng)執(zhí)行完所有任務(wù) # p.daemon = True # 啟動進(jìn)程 p.start() # 獲取進(jìn)程pid,如果在start函數(shù)之前獲取pid,默認(rèn)為None,因為進(jìn)程還沒啟動 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é)果:

進(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)用,其中就包括:

os.fork() 創(chuàng)建子進(jìn)程os.getpid() 獲取自身 IDos.getppid() 獲取父進(jìn)程 ID

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 昌邑市| 梅河口市| 南陵县| 抚顺县| 泊头市| 库伦旗| 赤城县| 大英县| 郸城县| 海林市| 米脂县| 丰城市| 安西县| 邹城市| 准格尔旗| 富顺县| 佳木斯市| 庆阳市| 泾源县| 永康市| 成都市| 广宗县| 日照市| 汉寿县| 西安市| 景泰县| 房山区| 阜新| 浑源县| 定襄县| 澳门| 鄂州市| 呼图壁县| 台北市| 双桥区| 玉山县| 汾西县| 井研县| 大石桥市| 北宁市| 广水市|