佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Python多線程以及多線程中join()的使用方法示例

Python多線程以及多線程中join()的使用方法示例

熱門標(biāo)簽:銀行業(yè)務(wù) 檢查注冊(cè)表項(xiàng) 服務(wù)器配置 美圖手機(jī) 智能手機(jī) 呼叫中心市場(chǎng)需求 鐵路電話系統(tǒng) 網(wǎng)站文章發(fā)布

Python多線程與多進(jìn)程中join()方法的效果是相同的。

下面僅以多線程為例:

首先需要明確幾個(gè)概念:

知識(shí)點(diǎn)一:

當(dāng)一個(gè)進(jìn)程啟動(dòng)之后,會(huì)默認(rèn)產(chǎn)生一個(gè)主線程,因?yàn)榫€程是程序執(zhí)行流的最小單元,當(dāng)設(shè)置多線程時(shí),主線程會(huì)創(chuàng)建多個(gè)子線程,在python中,默認(rèn)情況下(其實(shí)就是setDaemon(False)),主線程執(zhí)行完自己的任務(wù)以后,就退出了,此時(shí)子線程會(huì)繼續(xù)執(zhí)行自己的任務(wù),直到自己的任務(wù)結(jié)束,

見下面 例子一。

知識(shí)點(diǎn)二:

當(dāng)我們使用setDaemon(True)方法,設(shè)置子線程為守護(hù)線程時(shí),主線程一旦執(zhí)行結(jié)束,則全部線程全部被終止執(zhí)行,可能出現(xiàn)的情況就是,子線程的任務(wù)還沒有完全執(zhí)行結(jié)束,就被迫停止,

見下面例子二。

知識(shí)點(diǎn)三:

此時(shí)join的作用就凸顯出來了,join所完成的工作就是線程同步,即主線程任務(wù)在設(shè)置join函數(shù)的地方,進(jìn)入阻塞狀態(tài),一直等待其他的子線程執(zhí)行結(jié)束之后,主線程再開始執(zhí)行直到終止終止,

例子見下面三。

知識(shí)點(diǎn)四:

join有一個(gè)timeout參數(shù):

  • 當(dāng)有設(shè)置守護(hù)線程時(shí),含義是主線程對(duì)于子線程等待timeout的時(shí)間將會(huì)殺死該子線程,最后退出程序。所以說,如果有10個(gè)子線程,全部的等待時(shí)間就是每個(gè)timeout的累加和。簡(jiǎn)單的來說,就是給每個(gè)子線程一個(gè)timeout的時(shí)間,讓他去執(zhí)行,時(shí)間一到,不管任務(wù)有沒有完成,直接殺死。
  • 沒有設(shè)置守護(hù)線程時(shí),主線程將會(huì)等待timeout的累加和這樣的一段時(shí)間,時(shí)間一到,主線程結(jié)束,但是并沒有殺死子線程,子線程依然可以繼續(xù)執(zhí)行,直到子線程全部結(jié)束,程序退出。

一:Python多線程的默認(rèn)情況

import threading
import time

def run():
    time.sleep(2)
    print('當(dāng)前線程的名字是: ', threading.current_thread().name)
    time.sleep(2)


if __name__ == '__main__':

    start_time = time.time()

    print('這是主線程:', threading.current_thread().name)
    thread_list = []
    for i in range(5):
        t = threading.Thread(target=run)
        thread_list.append(t)

    for t in thread_list:
        t.start()

    print('主線程結(jié)束!' , threading.current_thread().name)
    print('一共用時(shí):', time.time()-start_time)

其執(zhí)行結(jié)果如下:

關(guān)鍵:

  • 計(jì)時(shí)是對(duì)主線程計(jì)時(shí),主線程結(jié)束,計(jì)時(shí)隨之結(jié)束,打印出主線程的用時(shí)。
  • 主線程的任務(wù)完成之后,主線程隨之結(jié)束,子線程繼續(xù)執(zhí)行自己的任務(wù),直到全部的子線程的任務(wù)全部結(jié)束,程序結(jié)束。

二:設(shè)置守護(hù)線程

import threading
import time

def run():

    time.sleep(2)
    print('當(dāng)前線程的名字是: ', threading.current_thread().name)
    time.sleep(2)


if __name__ == '__main__':

    start_time = time.time()

    print('這是主線程:', threading.current_thread().name)
    thread_list = []
    for i in range(5):
        t = threading.Thread(target=run)
        thread_list.append(t)

    for t in thread_list:
        t.setDaemon(True)
        t.start()

    print('主線程結(jié)束了!' , threading.current_thread().name)
    print('一共用時(shí):', time.time()-start_time)

注意:注意請(qǐng)確保setDaemon()在start()之前

其執(zhí)行結(jié)果如下:

關(guān)鍵點(diǎn):

非常明顯的看到,主線程結(jié)束以后,子線程還沒有來得及執(zhí)行,整個(gè)程序就退出了。

三:join的作用

import threading
import time

def run():

    time.sleep(2)
    print('當(dāng)前線程的名字是: ', threading.current_thread().name)
    time.sleep(2)


if __name__ == '__main__':

    start_time = time.time()

    print('這是主線程:', threading.current_thread().name)
    thread_list = []
    for i in range(5):
        t = threading.Thread(target=run)
        thread_list.append(t)

    for t in thread_list:
        t.setDaemon(True)
        t.start()

    for t in thread_list:
        t.join()

    print('主線程結(jié)束了!' , threading.current_thread().name)
    print('一共用時(shí):', time.time()-start_time)

其執(zhí)行結(jié)果如下:

關(guān)鍵點(diǎn):

可以看到,主線程一直等待全部的子線程結(jié)束之后,主線程自身才結(jié)束,程序退出。

主程序意外退出的情況

在線程A中使用B.join()表示線程A在調(diào)用join()處被阻塞,且要等待線程B的完成才能繼續(xù)執(zhí)行

import threading
import time


def child_thread1():
    for i in range(10):
        time.sleep(1)
        print('child_thread1_running...')


def child_thread2():
    for i in range(5):
        time.sleep(1)
        print('child_thread2_running...')


def parent_thread():
    print('parent_thread_running...')
    thread1 = threading.Thread(target=child_thread1)
    thread2 = threading.Thread(target=child_thread2)
    thread1.setDaemon(True)
    thread2.setDaemon(True)
    thread1.start()
    thread2.start()
    thread2.join()
    1/0
    thread1.join()
    print('parent_thread_exit...')


if __name__ == "__main__":
    parent_thread()

輸出:

parent_thread_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
Traceback (most recent call last):
  File "E:/test_thread.py", line 31, in module>
    parent_thread()
  File "E:/test_thread.py", line 25, in parent_thread
    1/0
ZeroDivisionError: integer division or modulo by zero

主線程在執(zhí)行到thread2.join()時(shí)被阻塞,等待thread2結(jié)束后才會(huì)執(zhí)行下一句

1/0會(huì)使主線程報(bào)錯(cuò)退出,且thread1設(shè)置了daemon=True,因此主線程意外退出時(shí)thread1也會(huì)立即結(jié)束。thread1.join()沒有被主線程執(zhí)行

總結(jié)

到此這篇關(guān)于Python多線程以及多線程中join()使用的文章就介紹到這了,更多相關(guān)Python多線程join()的用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python 多線程中join()的作用
  • python多線程編程中的join函數(shù)使用心得
  • Python多線程中阻塞(join)與鎖(Lock)使用誤區(qū)解析
  • 對(duì)python 多線程中的守護(hù)線程與join的用法詳解
  • Python多線程threading join和守護(hù)線程setDeamon原理詳解

標(biāo)簽:長(zhǎng)治 沈陽 紅河 滄州 樂山 河南 上海 新疆

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python多線程以及多線程中join()的使用方法示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    怀来县| 得荣县| 灯塔市| 鹤壁市| 南昌县| 临沭县| 巴中市| 遵义县| 绥德县| 米易县| 柳江县| 习水县| 郑州市| 彰化市| 尼木县| 栖霞市| 吴堡县| 甘南县| 洛阳市| 屏东市| 闽清县| 枝江市| 香格里拉县| 运城市| 诸暨市| 嫩江县| 雷山县| 乌审旗| 鞍山市| 郑州市| 湾仔区| 清涧县| 广州市| 利川市| 江西省| 赤城县| 三亚市| 平陆县| 旬邑县| 宁安市| 定远县|