• 技术文章 >Python技术 >Python基础教程

    python多线程中join的应用场景

    小妮浅浅小妮浅浅2021-05-13 09:46:32原创3090

    1、线程的join()方法表示等这个线程运行完毕,程序再往下运行。我们来看下面的例子

    from threading import Thread
    t = time.time()
    for _ in range(5):    
    th = Thread(target = myfun)    
    th.start()   
     th.join()print(time.time() - t)
    # 结果为 5.0047078132629395 秒

    2、这里start()之后马上join(),表示每一个线程都要运行结束才能进行下一次循环,这样就和没有使用多线程没有区别了。不过如果要计算多线程运行时间却是要用到这个join()

    我们先看一下不用join()的情况

    from threading import Thread
    t = time.time()
    for _ in range(5):    
    th = Thread(target = myfun)    
    th.start()print(time.time() - t)
    # 结果为  0.0009980201721191406 秒

    3、它连1秒都没有等,就输出了结果,而且5个2是在打印出这个之后才输出出来的。这是因为print(time.time() - t)是区别于那5次循环线程之外的第6个线程,它不会等待5个线程运行结束就会开始运行。所以这样是无法获得上面5个线程的运行时间的,我们需要用join()等待5个线程都运行结束。

    代码如下

    from threading import Thread
    t = time.time()ths = []
    for _ in range(5):    
    th = Thread(target = myfun)    
    th.start()    
    ths.append(th)for th in ths:    
    th.join()print(time.time() - t
    # 结果为 1.0038363933563232

    join()不只是用于这种情形。当一步代码运行依赖之前代码运行完成时,就要加入join()命令。

    以上就是python多线程中join的应用场景,希望能对大家有所帮助。更多Python学习指路:python基础教程

    本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

    专题推荐:python多线程 join
    上一篇:python异步中selectors的使用 下一篇:python进程池的使用注意

    相关文章推荐

    • python中使用Dockerfile构建镜像• threading在python中创建线程的两种方式• python中sys模块怎么用?• python实现异步的两种框架• python异步中selectors的使用

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网