1. 程式人生 > 程式設計 >Python使用程序Process模組管理資源

Python使用程序Process模組管理資源

程序Process是對各種資源管理的集合,包含對各種資源的呼叫、記憶體的管理、網路介面的呼叫;一個程序Process可以包含多個子程序,啟動一個程序的時候會自動建立一個執行緒,程序裡的第一個執行緒就是主執行緒(即python __name__ == ‘__main__');

程序Process模組

對於執行緒操作可以用threading模組,那麼對於程序的建立python同樣也提供了Process模組,建立程序時需要匯入該模組,語法如下:

# 匯入程序模組
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函式介紹

其實程序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字元的字串。這個鍵的用途是設計涉及網路連線的底層程序間的通訊提供安全性,這類連線只有在具有相同身份驗證才能成功;

程序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"},]
 
  # 建立程序
  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()

輸出結果:

程序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 模組封裝了常見的系統呼叫,其中就包括:

os.fork() 建立子程序
os.getpid() 獲取自身 ID
os.getppid() 獲取父程序 ID

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。