python 進程Process模塊(40)

目錄

一.進程Process簡介

二.進程Process模塊

三.進程Process函數介紹

四.進程Process使用

小竅門:

python進程Process與線程threading的區別

 


 

一.進程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

關於進程Process創建就介紹到這裏,不知道大家發現沒有,進程process的創建和線程threading的創建非常相似,那麼python進程和線程到底又有什麼區別呢?關於python進程和線程的區別請參考:python進程Process與線程threading的區別

 

 

 

 

猜你喜歡:

1.python 線程threading模塊

2.python 線程互斥鎖Lock

3.python 線程事件Event

4.python 線程定時器Timer

 

轉載請註明猿說Python » python 進程Process模塊

 

                                                                  技術交流、商務合作請直接聯繫博主

                                                                             掃碼或搜索:猿說python

python教程公衆號

                                                                                            猿說python

                                                                                      微信公衆號 掃一掃關注

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章