欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

什么是Python中的多進程

本篇文章為大家展示了什么是Python中的多進程,代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

我們提供的服務有:做網(wǎng)站、成都網(wǎng)站設計、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、蒙山ssl等。為千余家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的蒙山網(wǎng)站制作公司

多進程 multiprocessing

由于Python是跨平臺的,自然也應該提供一個跨平臺的多進程支持。multiprocessing模塊就是跨平臺版本的多進程模塊。

multiprocessing模塊提供了一個Process類來代表一個進程對象。

Unix/Linux操作系統(tǒng)提供了一個fork()系統(tǒng)調(diào)用,它非常特殊。普通的函數(shù)調(diào)用,調(diào)用一次,返回一次,但是fork()調(diào)用一次,返回兩次,因為操作系統(tǒng)自動把當前進程(稱為父進程)復制了一份(稱為子進程),然后,分別在父進程和子進程內(nèi)返回。

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

Python的os模塊封裝了常見的系統(tǒng)調(diào)用,其中就包括fork,可以在Python程序中輕松創(chuàng)建子進程:

import os
print('Process (%s) start...' % os.getpid())
# Only works on Unix/Linux/Mac:
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))

運行結果如下:

Process (69673) start ...
I (69673) just created a child Process(69674)
I am child proces (69674) and my parent is 69673.

有了fork調(diào)用,一個進程在接到新任務時就可以復制出一個子進程來處理新任務,常見的Apache服務器就是由父進程監(jiān)聽端口,每當有新的http請求時,就fork出子進程來處理新的http請求。

但是這個fork在windows操作系統(tǒng)是沒有的。于是出現(xiàn)了處理fork的通用模塊,以保證在不同操作系統(tǒng)間的調(diào)用。

multiprocessing模塊就是跨平臺版本的多進程模塊。

multiprocessing模塊提供了一個Process類來代表一個進程對象,下面的例子演示了啟動一個子進程并等待其結束:

#!/usr/bin/env python
# coding=utf-8
from multiprocessing import Process
import os
"""
    子進程要執(zhí)行的代碼
"""
def run_proc(name):
    print('Run child process %s (%s)' % (name, os.getpid()))
if __name__ == '__main__':
    print('Parent process %s.' % os.getpid())
    p = Process(target=run_proc, args=('test_code',))
    print('Child process will start.')
    p.start()
    p.join()
    print('Child process end.')

執(zhí)行結果如下:

$ python forkbymutilprocessing.py
Parent process 70227.
Child process will start.
Run child process test_code (70228)
Child process end.

創(chuàng)建子進程時,只需要傳入一個執(zhí)行函數(shù)和函數(shù)的參數(shù),創(chuàng)建一個Process實例,用start()方法啟動,這樣創(chuàng)建進程比fork()還要簡單。

join()方法可以等待子進程結束后再繼續(xù)往下運行,通常用于進程間的同步。

上述內(nèi)容就是什么是Python中的多進程,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享題目:什么是Python中的多進程
分享URL:http://chinadenli.net/article10/ghoodo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、網(wǎng)站策劃、ChatGPT、軟件開發(fā)、企業(yè)建站、全網(wǎng)營銷推廣

廣告

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

商城網(wǎng)站建設
久久99青青精品免费观看| 欧美日韩免费黄片观看| 91欧美日韩一区人妻少妇| 日韩三级黄色大片免费观看| 欧美日韩精品一区二区三区不卡| 亚洲另类欧美综合日韩精品| 中文字幕无线码一区欧美| 国产精品一区二区不卡中文| 亚洲精品国产主播一区| 日韩一区二区三区四区乱码视频| 一本色道久久综合狠狠躁| 久久精品国产亚洲av麻豆| 成人国产激情福利久久| 99精品人妻少妇一区二区人人妻| 好吊色欧美一区二区三区顽频 | 亚洲午夜精品视频在线| av一区二区三区天堂| 天堂热东京热男人天堂| 国产目拍亚洲精品区一区| 91熟女大屁股偷偷对白| 日本欧美三级中文字幕| 午夜福利视频六七十路熟女| 日韩一区二区三区在线日| 东北老熟妇全程露脸被内射| 91人妻人人澡人人人人精品| 国产精品日韩欧美第一页| 欧美成人久久久免费播放| 91福利视频日本免费看看| 亚洲精品伦理熟女国产一区二区| 美国黑人一级黄色大片| 亚洲欧美日韩在线看片| 韩国激情野战视频在线播放| 久久福利视频这里有精品| 东京热加勒比一区二区| 在线免费看国产精品黄片| 中文字幕一区二区熟女| 国产精品夜色一区二区三区不卡| 亚洲黄片在线免费小视频| 免费大片黄在线观看日本| 又色又爽又无遮挡的视频| 日本女人亚洲国产性高潮视频|