多线程threading初识二--多线程等待

.join() :子线程等待主线程

  下面程序运行流程:

主线程负责启动5个子线程,把每个线程放在threads list里,然后等待所有线程等待完毕后,再执行end_time = time.time()语句,实现最后计算所有线程都结束的并发时间。

主线程
     默认有个主线程
子线程:
    主线程启动子线程
import threading,time
def run():
    time.sleep(3):
    print('哈哈哈哈')

start_time = time.time()
threads=[]  #存放启动的5个子线程
for i in range(5):
    t = threading.Thread(target=run)  #实例化
    t.start() #启动线程
    threads.append(t) #启动后将子线程加入列表

for t in threads:  #主线程循环等待5个子线程执行结束
    t.join()  #循环等待,等所有线程执行完毕后,再执行下一句,即实现计算所有并发时间
end_time = time.time()
print('run_time',end_time-start_time)   

运行结果:并发时间:

 

转载于:https://www.cnblogs.com/fancyl/p/9101604.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值