亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

python中apply函數和apply_async函數有什么區別

發布時間:2022-06-10 15:48:17 來源:億速云 閱讀:372 作者:iii 欄目:開發技術

這篇文章主要介紹“python中apply函數和apply_async函數有什么區別”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“python中apply函數和apply_async函數有什么區別”文章能幫助大家解決問題。

1、二者的區別

apply(): 

  • 非異步(子進程不是同時執行的),堵塞主進程。

  • 它的非異步體現在:一個一個按順序執行子進程, 子進程不是同時執行的。

  • 它的堵塞體現在:等到全部子進程都執行完畢后,繼續執行apply()后面主進程的代碼。

apply_async():

  • 異步的,不堵塞主進程。

  • 它的異步體現在:子進程之間是同時執行的。子進程被分配到不同的cpu上被執行。

  • 它的非堵塞體現在:他不會等待子進程完全執行完畢, 主進程會繼續執行, 他會根據系統調度來進行進程之間的切換。如果想堵塞主要進程,需要用.join()函數來堵塞主進程。

2、apply()

import time
import multiprocessing
def doIt(num):
    print("Process num is : %s" % num)
    time.sleep(1)
    print('process  %s end' % num)

if __name__ == '__main__':
    print('mainProcess start')

    #記錄一下開始執行的時間
    start_time = time.time()
    # 創建一個進程池,允許最多可以有3個子進程可以同時執行。
    pool = multiprocessing.Pool(3)

    print('Child start')
    for i in range(3):
         pool.apply(doIt,[i])
    print('mainProcess done time:%s s' % (time.time() - start_time))

結果如下所示:

從結果中我們可以看到,主進程開始執行之后, 創建的三個子進程也隨即開始執行, 后面的主進程被阻塞。而且三個子進程是一個接一個按順序地執行, 等到子進程全部執行完畢之后, 后面的主進程才會繼續執行, 打印出最后一句。所以,apply()函數果然是可以堵塞主進程,而且是非異步的。

python中apply函數和apply_async函數有什么區別

3、apply_async()

顧名思義,async就是異步的意思。接下來是使用apply_async(), 只需要把上面的代碼使用 apply()的地方改成apply_async() 即可, 代碼不再貼上
我們來看看運行結果, 可以看出來, 截圖的第一句是上一個程序(也就是apply()函數)的執行消耗時間, 
最后一句是使用apply_async()所消耗的時間, 在這里, 主進程沒有被阻塞, 驗證了apply_async()是非阻塞主進程的, 子進程沒有執行, 驗證了他是根據系統調度完成的,

為什么會這樣呢?

原因是, 進程的切換時操作系統控制的, 我們首先運行的是主進程, 而CPU運行得又很快, 快到還沒等系統調度到子線程, 主進程就已經運行完畢了, 并且退出程序. 所以子進程就沒有運行了.

python中apply函數和apply_async函數有什么區別

那么我們在使用apply_async()函數是不是就不能執行子進程呢?肯定可以啊!!!小老弟,想啥呢??還記得join()的作用嗎?他可以阻塞主進程, 等待所有子進程結束之后再運行,join()就是告訴主進程老子要運行子進程了,你先等等。 

import time
import multiprocessing

def doIt(num):
    print("Process num is : %s" % num)
    time.sleep(1)
    print('process  %s end' % num)
if __name__ == '__main__':
    print('mainProcess start')

    #記錄一下開始執行的時間
    start_time = time.time()
    # 創建一個進程池,最大允許3個子進程同時執行。
    pool = multiprocessing.Pool(3)
    print('Child start')
    for i in range(3):
        pool.apply_async(doIt,[i])
    pool.close()
    pool.join()
    print('mainProcess done time:%s s' % (time.time() - start_time))

結果如下所示:

我們看看加入這兩句的運行結果, 我們可以看到即使是使用了非阻塞主進程的apply_async() 也能讓子進程運行完畢之后再執行主進程了。
CPU在執行第一個子進程的時候, 還沒等第一個子進程結束, 系統調度到了按順序調度到了第二個子進程, 以此類推, 一直調度運行子進程, 一個接一個地結束子進程的運行, 最后運行主進程, 而且我們可以看到使用apply_async()的執行效力會更高,看一下他們各自執行結果最后一句的執行消耗時間就知道了, 這也是官方推薦我們使用apply_async()的主要原因吧

python中apply函數和apply_async函數有什么區別

關于“python中apply函數和apply_async函數有什么區別”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

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

AI

黄平县| 洛宁县| 通河县| 霞浦县| 招远市| 乌审旗| 石阡县| 南通市| 贵定县| 建瓯市| 西安市| 望奎县| 宁乡县| 澎湖县| 西青区| 韶关市| 兴义市| 县级市| 文水县| 新干县| 东阳市| 通化市| 盖州市| 安吉县| 乌苏市| 峨山| 弥勒县| 略阳县| 临夏县| 周至县| 鹿邑县| 阳曲县| 家居| 孟州市| 和政县| 昭平县| 福州市| 楚雄市| 香河县| 茌平县| 察雅县|