Python中多线程与join()的应用
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
可以看到,主线程一直等待全部的子线程结束之后,主线程自身才结束,程序退出。