首页 > 技术文章 > Python中多线程与join()的应用

cokefentas 2019-06-28 09:28 原文

threading.active_count() 查看当前已激活的线程
threading.enumerate() 查看当前所有的线程
threading.current_thread() 查看当前线程(主线程)
threading.Thread(target=函数名)

1,当一个进程启动之后,会默认产生一个主线程,设置多线程时,主线程会创建多个子线程,在python中,默认情况下主线程执行完自己的任务以后,就退出了,此时子线程会继续执行自己的任务,直到自己的任务结束。

import threading as td
import time

def job():
    time.sleep(2)
    print('当前线程的名字是:',td.current_thread().name)
    time.sleep(2)

if __name__ == '__main__':
    start_time = time.time()
    thread_list = []
    for i in range(5):
        t = td.Thread(target=job)
        thread_list.append(t)

    for t in thread_list:
        t.start()

    print('主线程结束:',td.current_thread().name)
    print('一共用时:',time.time()-start_time)
>>>
主线程结束: MainThread
一共用时: 0.0009999275207519531
当前线程的名字是: Thread-1当前线程的名字是: Thread-2

当前线程的名字是: Thread-3
当前线程的名字是: 当前线程的名字是:Thread-4
 Thread-5

我们的计时是对主线程计时,主线程结束,计时随之结束,打印出主线程的用时。

主线程的任务完成之后,主线程随之结束,子线程继续执行自己的任务,直到全部的子线程的任务全部结束,程序结束。

2,当我们使用setDaemon(True)方法,设置子线程为守护线程时,主线程一旦执行结束,则全部线程全部被终止执行,可能出现的情况就是,子线程的任务还没有完全执行结束,就被迫停止。

import threading as td
import time

def job():
    time.sleep(2)
    print('当前线程的名字是:',td.current_thread().name)
    time.sleep(2)

if __name__ == '__main__':
    start_time = time.time()
    thread_list = []
    for i in range(5):
        t = td.Thread(target=job)
        thread_list.append(t)

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

    print('主线程结束:',td.current_thread().name)
    print('一共用时:',time.time()-start_time)
>>>
主线程结束: MainThread
一共用时: 0.0009999275207519531

非常明显的看到,主线程结束以后,子线程还没有来得及执行,整个程序就退出了。

3,join所完成的工作就是线程同步,即主线程任务结束之后,进入阻塞状态,一直等待其他的子线程执行结束之后,主线程在终止。

import threading as td
import time

def job():
    time.sleep(2)
    print('当前线程的名字是:',td.current_thread().name)
    time.sleep(2)

if __name__ == '__main__':
    start_time = time.time()
    thread_list = []
    for i in range(5):
        t = td.Thread(target=job)
        thread_list.append(t)

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

    for t in thread_list:
        t.join()

    print('主线程结束:',td.current_thread().name)
    print('一共用时:',time.time()-start_time)
>>>
当前线程的名字是: Thread-1
当前线程的名字是: Thread-3
当前线程的名字是: Thread-4
当前线程的名字是: Thread-5 
当前线程的名字是:Thread-2
主线程结束: MainThread
一共用时: 4.0012288093566895

可以看到,主线程一直等待全部的子线程结束之后,主线程自身才结束,程序退出。

推荐阅读