Python -- 高并发,更好用的原生库concurrent

环境

  • Python3.2+
  • 标准库concurrent.futures模块
线程池
  • ThreadPoolExecutor
from concurrent.futures import ThreadPoolExecutor
进程池
  • ProcessPoolExecutor
from concurrent.futures import ProcessPoolExecutor

代码示例

from time import sleep, time
from threading import current_thread
from concurrent.futures import ThreadPoolExecutor


# 返回 当前线程名称
thread_name = lambda: current_thread().getName()


# 任务函数
def work(num):
    print("正在下载", num, "当前线程:", thread_name())
    sleep(1)
    print("下载完成", num, "当前线程:", thread_name())


# 多线程执行任务
def multi_thread():
    with ThreadPoolExecutor(max_workers=3) as thread_pool:
        for num in range(3):
            thread_pool.submit(work, num)


# 主函数
def main():
    multi_thread()


if __name__ == '__main__':
    t1 = time()
    main()
    print("耗时:", time() - t1)

执行结果

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值