python的Process進(jìn)程介紹和使用-創(chuàng)新互聯(lián)

一.Process簡(jiǎn)介

進(jìn)程(Process)是計(jì)算機(jī)中的程序關(guān)于某數(shù)據(jù)集合上的一次運(yùn)行活動(dòng),是系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位,是操作系統(tǒng)結(jié)構(gòu)的基礎(chǔ)。在早期面向進(jìn)程設(shè)計(jì)的計(jì)算機(jī)結(jié)構(gòu)中,進(jìn)程是程序的基本執(zhí)行實(shí)體;在當(dāng)代面向線程設(shè)計(jì)的計(jì)算機(jī)結(jié)構(gòu)中,進(jìn)程是線程的容器。程序是指令、數(shù)據(jù)及其組織形式的描述,進(jìn)程是程序的實(shí)體。

成都創(chuàng)新互聯(lián)是一家集成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、網(wǎng)站頁面設(shè)計(jì)、網(wǎng)站優(yōu)化SEO優(yōu)化為一體的專業(yè)網(wǎng)站建設(shè)公司,已為成都等多地近百家企業(yè)提供網(wǎng)站建設(shè)服務(wù)。追求良好的瀏覽體驗(yàn),以探求精品塑造與理念升華,設(shè)計(jì)最適合用戶的網(wǎng)站頁面。 合作只是第一步,服務(wù)才是根本,我們始終堅(jiān)持講誠信,負(fù)責(zé)任的原則,為您進(jìn)行細(xì)心、貼心、認(rèn)真的服務(wù),與眾多客戶在蓬勃發(fā)展的市場(chǎng)環(huán)境中,互促共生。

二.進(jìn)程Process模塊

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

# 導(dǎo)入進(jìn)程模塊

frommultiprocessingimportProcess

# 創(chuàng)建進(jìn)程

p=Process(group=None,target=None,name=None,args=(),kwargs={})

1

2

3

4

5

參數(shù)介紹:

group — 參數(shù)未使用,默認(rèn)值為None;

target — 表示調(diào)用對(duì)象,即子進(jìn)程要執(zhí)行的任務(wù)(函數(shù)名字);

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

四.進(jìn)程Process使用

# !usr/bin/env python

# -*- coding:utf-8 _*-

"""

@Author:何以解憂

@Blog(個(gè)人博客地址): shuopython.com

@WeChat Official Account(微信公眾號(hào)):猿說python

@Github:www.github.com

@File:python_process.py

@Time:2019/12/21 21:25

@Motto:不積跬步無以至千里,不積小流無以成江海,程序人生的精彩需要堅(jiān)持不懈地積累!

"""

frommultiprocessingimportProcess

defpeople_info(*args,**kwargs):

    print(args,kwargs)

defmain():

    # 信息列表

    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)程

    foriinrange(5):

        p=Process(target=people_info,args=(i,),kwargs=list_info[i])

        # 設(shè)置為守護(hù)進(jìn)程,必須設(shè)置在start函數(shù)之前,否則會(huì)產(chǎn)生異常

        # 默認(rèn)為False,即主進(jìn)程會(huì)等待子進(jìn)程結(jié)束之后才結(jié)束,

        # 如果設(shè)置為True,主進(jìn)程結(jié)束之后所有的子進(jìn)程自動(dòng)結(jié)束,不管子進(jìn)程是否已經(jīng)執(zhí)行完所有任務(wù)

        # p.daemon = True

        # 啟動(dòng)進(jìn)程

        p.start()

        # 獲取進(jìn)程pid,如果在start函數(shù)之前獲取pid,默認(rèn)為None,因?yàn)檫M(jìn)程還沒啟動(dòng)

        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()

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

輸出結(jié)果:

進(jìn)程processpid=  2600

進(jìn)程processname=  Process-1

進(jìn)程processexitcode=  None

進(jìn)程processpid=  4372

進(jìn)程processname=  Process-2

進(jìn)程processexitcode=  None

進(jìn)程processpid=  14124

進(jìn)程processname=  Process-3

進(jìn)程processexitcode=  None

進(jìn)程processpid=  10920

進(jìn)程processname=  Process-4

進(jìn)程processexitcode=  None

進(jìn)程processpid=  4892

進(jìn)程processname=  Process-5

進(jìn)程processexitcode=  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'}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

小竅門:

Python 的 os 模塊封裝了常見的系統(tǒng)調(diào)用,其中就包括:

os.fork() 創(chuàng)建子進(jìn)程

os.getpid() 獲取自身ID

os.getppid() 獲取父進(jìn)程ID

1

2

3

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)頁標(biāo)題:python的Process進(jìn)程介紹和使用-創(chuàng)新互聯(lián)
文章起源:http://bm7419.com/article10/goigo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)網(wǎng)站收錄、虛擬主機(jī)、營銷型網(wǎng)站建設(shè)、網(wǎng)站制作、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)