• 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

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

  • 相关阅读:
    Scrapy框架实现持久化存储
    Scrapy框架的介绍和基本使用
    处理页面动态加载数据
    爬虫数据解析
    Python爬虫基础
    Flask详解(下篇)
    Flask详解(中篇)
    CentOS 中的性能监测命令vmstat
    CentOS 7安装MySQL 8.0.15
    CF B.Kind Anton(4月8号)
  • 原文地址:https://www.cnblogs.com/cokefentas/p/11100923.html
Copyright © 2020-2023  润新知