亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python多進(jìn)程fork()函數(shù)詳解

 更新時(shí)間:2019年02月22日 08:33:32   作者:世界看我我看世界  
今天小編就為大家分享一篇關(guān)于Python多進(jìn)程fork()函數(shù)詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧

進(jìn)程

進(jìn)程是程序的一次動(dòng)態(tài)執(zhí)行過(guò)程,它對(duì)應(yīng)了從代碼加載、執(zhí)行到執(zhí)行完畢的一個(gè)完整過(guò)程。進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個(gè)獨(dú)立單位。進(jìn)程是由代碼(堆棧段)、數(shù)據(jù)(數(shù)據(jù)段)、內(nèi)核狀態(tài)和一組寄存器組成。

在多任務(wù)操作系統(tǒng)中,通過(guò)運(yùn)行多個(gè)進(jìn)程來(lái)并發(fā)地執(zhí)行多個(gè)任務(wù)。由于每個(gè)線程都是一個(gè)能獨(dú)立執(zhí)行自身指令的不同控制流,因此一個(gè)包含多個(gè)線程的進(jìn)程也能夠?qū)崿F(xiàn)進(jìn)程內(nèi)多任務(wù)的并發(fā)執(zhí)行。

進(jìn)程是一個(gè)內(nèi)核級(jí)的實(shí)體,進(jìn)程結(jié)構(gòu)的所有成分都在內(nèi)核空間中,一個(gè)用戶程序不能直接訪問(wèn)這些數(shù)據(jù)。

進(jìn)程的狀態(tài):

創(chuàng)建、準(zhǔn)備、運(yùn)行、阻塞、結(jié)束。

進(jìn)程間的通信方式可以有:

  • 文件
  • 管道
  • socket
  • 信號(hào)
  • 信號(hào)量
  • 共享內(nèi)存

要讓Python程序?qū)崿F(xiàn)多進(jìn)程(multiprocessing),必須先了解操作系統(tǒng)的相關(guān)知識(shí)。

在Unix/Linux操作系統(tǒng)提供了一個(gè)fork()函數(shù),它非常特殊,調(diào)用一次,返回兩次,因?yàn)椴僮飨到y(tǒng)將當(dāng)前的進(jìn)程(父進(jìn)程)復(fù)制了一份(子進(jìn)程),然后分別在父進(jìn)程和子進(jìn)程內(nèi)返回。

Python中的進(jìn)程

  • os.fork()
  • subprocess
  • processing
  • multiprocessing

fork()函數(shù)

函數(shù)原型:

Help on built-in function fork in module posix:
fork(...)
  fork() -> pid
  Fork a child process.
  Return 0 to child process and PID of child to parent process.

從fork()函數(shù)原型來(lái)看,它也屬于一個(gè)內(nèi)建函數(shù)。

子進(jìn)程永遠(yuǎn)返回0,而父進(jìn)程返回子進(jìn)程的ID。這樣做的理由是,一個(gè)父進(jìn)程可以fork()出很多子進(jìn)程,所以,父進(jìn)程要記下每個(gè)子進(jìn)程的ID,而子進(jìn)程只需要調(diào)用getppid()就可以拿到父進(jìn)程的ID。

Python的進(jìn)程函數(shù)fork()是在os模塊,下面是一個(gè)關(guān)于進(jìn)程的例子:

import os
print os.getpid() #獲取子進(jìn)程的進(jìn)程號(hào)
pid = os.fork()
if pid == 0 :
 print 'I am child process (%s) and my parent is %s.' % (os.getpid(), os.getppid())
else :
 print 'I (%s) just created a child process (%s).' % (os.getpid(), pid)

執(zhí)行結(jié)果:

1526
I (1526) just created a child process (1527).
I am child process (1527) and my parent is 1526.

有了fork調(diào)用,一個(gè)進(jìn)程在接到新的任務(wù)時(shí),就可以復(fù)制出一個(gè)子進(jìn)程來(lái)處理新任務(wù)。常見(jiàn)的Apache服務(wù)器就是由父進(jìn)程監(jiān)聽(tīng)端口,一旦有新的http請(qǐng)求時(shí),就fork出子進(jìn)程來(lái)處理新的http請(qǐng)求。

再看一個(gè)例子:

#coding=utf-8
import os
os.fork()
print 1

執(zhí)行結(jié)果:

1
1

程序中,父進(jìn)程中創(chuàng)建了一個(gè)子進(jìn)程,子進(jìn)程運(yùn)行打印了一個(gè)1,回到父進(jìn)程又打印了一個(gè)1,所以結(jié)果是打印了2個(gè)1。

需要注意的是,上面創(chuàng)建進(jìn)程的函數(shù)都是Unix/Linux下的,Windows下是沒(méi)有的,那在Windows下又使用什么實(shí)現(xiàn)多進(jìn)程呢?

由于Python是跨平臺(tái)的,自然也應(yīng)該提供一個(gè)跨平臺(tái)的多進(jìn)程支持。multiprocessing模塊就是跨平臺(tái)版本的多進(jìn)程模塊, 支持子進(jìn)程、通信和共享數(shù)據(jù)、執(zhí)行不同形式的同步。

multiprocessing模塊提供了一個(gè)Process類來(lái)創(chuàng)建一個(gè)新的進(jìn)程對(duì)象。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • python修改字典內(nèi)key對(duì)應(yīng)值的方法

    python修改字典內(nèi)key對(duì)應(yīng)值的方法

    這篇文章主要介紹了python修改字典內(nèi)key對(duì)應(yīng)值的方法,涉及Python中字典賦值的相關(guān)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • python實(shí)現(xiàn)圖書(shū)館研習(xí)室自動(dòng)預(yù)約功能

    python實(shí)現(xiàn)圖書(shū)館研習(xí)室自動(dòng)預(yù)約功能

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)圖書(shū)館研習(xí)室自動(dòng)預(yù)約功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Python中random模塊生成隨機(jī)數(shù)詳解

    Python中random模塊生成隨機(jī)數(shù)詳解

    本文給大家匯總了一下在Python中random模塊中最常用的生成隨機(jī)數(shù)的方法,有需要的小伙伴可以參考下
    2016-03-03
  • 超實(shí)用的 10 段 Python 案例

    超實(shí)用的 10 段 Python 案例

    Python是目前最流行的語(yǔ)言之一,它在數(shù)據(jù)科學(xué)、機(jī)器學(xué)習(xí)、web開(kāi)發(fā)、腳本編寫、自動(dòng)化方面被許多人廣泛使用。它的簡(jiǎn)單和易用性造就了它如此流行的原因。今天這篇文章就給大家分享 10 段超級(jí)有用的 Python 案例,需要的朋友可以參考一下
    2021-09-09
  • Python基礎(chǔ)入門之魔法方法與異常處理

    Python基礎(chǔ)入門之魔法方法與異常處理

    在python中,所有以“__"雙下劃線包起來(lái)的方法,都統(tǒng)稱為魔法方法,下面這篇文章主要給大家介紹了關(guān)于Python基礎(chǔ)入門之魔法方法與異常處理的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • 如何使用pyinstaller打包時(shí)引入自己編寫的庫(kù)

    如何使用pyinstaller打包時(shí)引入自己編寫的庫(kù)

    這篇文章主要介紹了如何使用pyinstaller打包時(shí)引入自己編寫的庫(kù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Python使用python-docx讀寫word文檔

    Python使用python-docx讀寫word文檔

    這篇文章主要為大家詳細(xì)介紹了Python使用python-docx讀寫word文檔,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • python中添加模塊導(dǎo)入路徑的方法

    python中添加模塊導(dǎo)入路徑的方法

    這篇文章主要介紹了python中添加模塊導(dǎo)入路徑的方法 ,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • 詳解Python列表解析式的使用方法

    詳解Python列表解析式的使用方法

    Python?是一種極其多樣化和強(qiáng)大的編程語(yǔ)言!當(dāng)需要解決一個(gè)問(wèn)題時(shí),它有著不同的方法。本文將將會(huì)展示列表解析式的使用方法,需要的可以參考一下
    2022-04-04
  • pyinstaller通過(guò)spec文件打包py程序的步驟

    pyinstaller通過(guò)spec文件打包py程序的步驟

    這篇文章主要介紹了pyinstaller通過(guò)spec文件打包py程序,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05

最新評(píng)論