python并发编程实战(九):使用多进程multiprocessing模块加速程序的运行

1|0有了多线程threading,为什么还要用多进程multiprocessing


2|0多进程multiprocessing知识梳理(对比多线程threading)


3|0代码实战:单线程、多线程、多进程对比CPU密集计算速度


tmp/06.thread_process_cpu_bound.py

import math from concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor import time PRIMES = [112272535095293] * 100 def is_prime(n): if n < 2: return False if n == 2: return True if n % 2 == 0: return False sqrt_n = int(math.floor(math.sqrt(n))) for i in range(3, sqrt_n + 1, 2): if n % i == 0: return False return True def single_thread(): for number in PRIMES: is_prime(number) def multi_thread(): with ThreadPoolExecutor() as pool: pool.map(is_prime, PRIMES) def multi_process(): with ProcessPoolExecutor() as pool: pool.map(is_prime, PRIMES) if __name__ == '__main__': start = time.time() single_thread() end = time.time() print("single_thread, cost: ", end - start, "seconds") start = time.time() multi_thread() end = time.time() print("multi_thread, cost: ", end - start, "seconds") start = time.time() multi_process() end = time.time() print("multi_process, cost: ", end - start, "seconds")

运行结果:


__EOF__

本文作者cnhkzyy
本文链接https://www.cnblogs.com/my_captain/p/16444937.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   cnhkzyy  阅读(112)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2018-07-05 os.path.abs()与os.path.realpath()的一点区别
2018-07-05 web自动化中的page object模式
2018-07-05 刷题(一)
2018-07-05 python递归中的return"陷阱"
点击右上角即可分享
微信分享提示