您好,登錄后才能下訂單哦!
進程(Process)是計算機中的程序關于某數據集合上的一次運行活動,是系統進行資源分配和調度的基本單位,是操作系統結構的基礎。在早期面向進程設計的計算機結構中,進程是程序的基本執行實體;在當代面向線程設計的計算機結構中,進程是線程的容器。程序是指令、數據及其組織形式的描述,進程是程序的實體。
對于線程操作可以用threading模塊,那么對于進程的創建python同樣也提供了Process模塊,創建進程時需要導入該模塊,語法如下:
1 2 3 4 5 | # 導入進程模塊 from multiprocessing import Process
# 創建進程 p = Process(group=None, target=None, name=None, args=(), kwargs={}) |
參數介紹:
group — 參數未使用,默認值為None;
target — 表示調用對象,即子進程要執行的任務(函數名字);
args — 子進程對應函數的參數,并且類型是元組tuple;
kwargs — 子進程對應函數的參數,并且類型是字典dict,如kwargs = {‘name’:Jack, ‘age’:18};
name — 子進程名稱;
返回值:返回進程實例對象;
其實進程Process的函數和線程threading類似,具體如下:
1.start() — 啟動進程;
2.terminate() — 強制終止進程,不會進行任何清理操作。如果該進程終止前,創建了子進程,那么該子進程在其強制結束后變為僵尸進程;如果該進程還保存了一個鎖那么也將不會被釋放,進而導致死鎖,使用時,要注意;
3.is_alive() — 判斷某進程是否存活,存活返回True,否則False;
4.join([timeout]) — 主線程等待子線程終止。timeout為可選擇超時時間;需要強調的是,p.join只能join住start開啟的進程,而不能join住run開啟的進程 ;
5.daemon — 默認值為False,如果設置為True,代表該進程為后臺守護進程;當該進程的父進程終止時,該進程也隨之終止;并且設置為True后,該進程不能創建子進程,設置該屬性必須在start()之前;
6.name — 進程名稱;
7.pid— 進程ID標識,pid,值得注意的是:如果在start函數之前獲取pid默認為None,因為進程還未創建,獲取不到pid;
8.exitcode — 進程運行時為None,如果為-N,表示被信號N結束了;
9.authkey — 進程身份驗證,默認是由os.urandom()隨機生成32字符的字符串。這個鍵的用途是設計涉及網絡連接的底層進程間的通信提供安全性,這類連接只有在具有相同身份驗證才能成功;
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:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅持不懈地積累! """
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"},]
# 創建進程 for i in range(5): p = Process(target=people_info,args=(i,),kwargs=list_info[i]) # 設置為守護進程,必須設置在start函數之前,否則會產生異常 # 默認為False,即主進程會等待子進程結束之后才結束, # 如果設置為True,主進程結束之后所有的子進程自動結束,不管子進程是否已經執行完所有任務 # p.daemon = True
# 啟動進程 p.start()
# 獲取進程pid,如果在start函數之前獲取pid,默認為None,因為進程還沒啟動 print("進程process pid = ",p.pid) # 獲取進程名字 print("進程process name = ",p.name) # 獲取進程pid print("進程process exitcode = ",p.exitcode)
if __name__ == "__main__": main() |
輸出結果:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | 進程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
模塊封裝了常見的系統調用,其中就包括:
1 2 3 | os.fork() 創建子進程 os.getpid() 獲取自身 ID os.getppid() 獲取父進程 ID |
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。