zoukankan      html  css  js  c++  java
  • python3对多线程处理

    参考博客: https://blog.csdn.net/u010339879/article/details/86506450

    https://blog.csdn.net/qq_33961117/article/details/82462745

    python线程介绍官网: https://docs.python.org/3/library/threading.html?highlight=threading#

    python编程语言里面的任务和线程是很重要的一个功能, 这里面涉及到很多的东西, 具体可以查看上面我参考的博客地址,

    这里只写出我个人对python多线程的理解.

    先看下面的代码(摘抄其他博客, 同时自己在真实环境运行(我用的是python3.7.3版本)):

    import threading
    import time
    
    def T1_job():
        print('T1 start')
        for i in range(10):
            print('begin sleep 0.1s')
            time.sleep(0.1)
        print('T1 finish')
    
    def T2_job():
        print('T2 start')
        print('T2 finish')
    
    def main():
        print('---main begin----')
        t1 = threading.Thread(target=T1_job, name='T1')
        t2 = threading.Thread(target=T2_job, name='T2')
        t1.start()
        t2.start()
        print('---main end----')
    
    if __name__ == '__main__':
        main()

    运行结果如下:
    ---main begin----
    ---main end----
    T2 start
    T1 start
    begin sleep 0.1s
    T2 finish
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    begin sleep 0.1s
    T1 finish

    主线程,main 很快就结束了, 子线程 T2先开始,然后 T1开始, T2很快就完成任务了, 然后经过漫长的等待最后也完成任务了. 这是没有用join 的情况. 即使 主线程main 停止了, 两个子线程 并不会直接退出. 而是要把自己各自的任务完成, 才会退出.

    不知道T1还是T2先运行,代码里写的是T1开始, 但是打印出Log是T2先开始, 这可能和线程执行的任务多少有关系吧(个人理解),具体原因可能就是多线程造成的. 

    这里通过join ,可以让线程在这里等着,阻塞在这里,等线程跑完了

    join 有一个参数 timeout 意思是等待时间, 如果超过等待的时间, 任务还没有完成那就不等待了,直接继续跑下面的代码.
    如果任务 完成的时候, 没有超过等待时间, 那么就正常往下跑.

    timeout 是一个float number 单位是秒

    看下面的代码测试, 使用join来等待线程:

    import threading
    import time
    
    def T1_job():
        print('T1 start')
        for i in range(10):
            print('begin sleep 0.5s')
            time.sleep(0.5)
        print('T1 finish')
    
    def T2_job():
        print('T2 start')
        print('T2 finish')
    
    def main():
        print('---main begin----')
        t1 = threading.Thread(target=T1_job, name='T1')
        t2 = threading.Thread(target=T2_job, name='T2')
        t1.start()
        t2.start()
    
        t1.join(timeout=3)
        print("t1 done")
    
        t2.join()
        print("t2 done")
        print('---main end----')
    运行结果如下:
    ---main begin----
    T1 start
    begin sleep 0.5s
    T2 start
    T2 finish
    begin sleep 0.5s
    begin sleep 0.5s
    begin sleep 0.5s
    begin sleep 0.5s
    begin sleep 0.5s
    t1 done     # t1 继续往下跑
    t2 done
    ---main end----
    begin sleep 0.5s
    begin sleep 0.5s
    begin sleep 0.5s
    begin sleep 0.5s
    T1 finish
  • 相关阅读:
    尚硅谷面试第一季-05递归与迭代
    尚硅谷面试第一季-04方法的参数传递机制
    尚硅谷面试第一季-03类初始化和实例初始化
    python爬爬爬之单网页html页面爬取
    python之花瓣美女下载
    (转载博文)VC++API速查
    (转载博文)MFC 窗口句柄获取
    全局变量的声明
    python图片小爬虫
    Opencv2.4.4作图像旋转和缩放
  • 原文地址:https://www.cnblogs.com/xumBlog/p/11014224.html
Copyright © 2011-2022 走看看