中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在python中使用Process模塊

發布時間:2021-05-11 16:00:22 來源:億速云 閱讀:302 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關如何在python中使用Process模塊,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

Python的優點有哪些

1、簡單易用,與C/C++、Java、C# 等傳統語言相比,Python對代碼格式的要求沒有那么嚴格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺上使用;3、Python面向對象,能夠支持面向過程編程,也支持面向對象編程;4、Python是一種解釋性語言,Python寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序;5、Python功能強大,擁有的模塊眾多,基本能夠實現所有的常見功能。

一.進程Process簡介

進程Process是對各種資源管理的集合,包含對各種資源的調用、內存的管理、網絡接口的調用;一個進程Process可以包含多個子進程,啟動一個進程的時候會自動創建一個線程,進程里的第一個線程就是主線程(即python __name__ == ‘__main__’);

二.進程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函數介紹

其實進程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使用

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

以上就是如何在python中使用Process模塊,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高淳县| 凤山市| 锡林浩特市| 郁南县| 阿克| 元氏县| 南安市| 双辽市| 冀州市| 大城县| 黄平县| 浏阳市| 浙江省| 平安县| 潍坊市| 运城市| 金乡县| 襄垣县| 孟州市| 姚安县| 庄浪县| 景东| 丰镇市| 南靖县| 临泉县| 栾川县| 义马市| 泉州市| 含山县| 富锦市| 嘉善县| 白山市| 元氏县| 香格里拉县| 昭通市| 珠海市| 赣榆县| 新巴尔虎右旗| 界首市| 罗甸县| 乐清市|