我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python多进程与多线程的使用场景有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python多进程与多线程的使用场景有哪些

这篇文章主要介绍Python多进程与多线程的使用场景有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

前言

Python多进程适用的场景:计算密集型(CPU密集型)任务

Python多线程适用的场景:IO密集型任务

计算密集型任务一般指需要做大量的逻辑运算,比如上亿次的加减乘除,使用多核CPU可以并发提高计算性能。

IO密集型任务一般指输入输出型,比如文件的读取,或者网络的请求,这类场景一般会遇到IO阻塞,使用多核CPU来执行并不会有太高的性能提升。

下面使用一台64核的虚拟机来执行任务,通过示例代码来区别它们,

示例1:执行计算密集型任务,进行1亿次运算

使用多进程

from multiprocessing import Processimport os, time  # 计算密集型任务def work(): res = 0 for i in range(100 * 100 * 100 * 100): # 亿次运算  res *= i  if __name__ == "__main__": l = [] print("本机为", os.cpu_count(), "核 CPU") # 本机为64核 start = time.time() for i in range(4):  p = Process(target=work) # 多进程  l.append(p)  p.start() for p in l:  p.join() stop = time.time() print("计算密集型任务,多进程耗时 %s" % (stop - start))

使用多线程

from threading import Threadimport os, time  # 计算密集型任务def work(): res = 0 for i in range(100 * 100 * 100 * 100): # 亿次运算  res *= i  if __name__ == "__main__": l = [] print("本机为", os.cpu_count(), "核 CPU") # 本机为64核 start = time.time() for i in range(4):  p = Thread(target=work) # 多线程  l.append(p)  p.start() for p in l:  p.join() stop = time.time() print("计算密集型任务,多线程耗时 %s" % (stop - start))

两段代码输出:

本机为 64 核 CPU
计算密集型任务,多进程耗时 6.864224672317505
 
本机为 64 核 CPU
计算密集型任务,多线程耗时 37.91042113304138

说明:上述代码中,分别使用4个多进程和4个多线程去执行亿次运算,多进程耗时6.86s,多线程耗时37.91s,可见在计算密集型任务场景,使用多进程能大大提高效率。

另外,当分别使用8个多进程和8个多线程去执行亿次运算时,耗时差距更大,输出如下:

本机为 64 核 CPU
计算密集型任务,多进程耗时 6.811635971069336
 
本机为 64 核 CPU
计算密集型任务,多线程耗时 113.53767895698547

可见在64核的cpu机器下,同时使用8个多进程和4个多进程效率几乎一样。而使用多线程则就效率较慢。要最高效地利用CPU,计算密集型任务同时进行的数量应当等于CPU的核心数

示例2:400次,阻塞两秒,读取文件

使用多进程(4核cpu)

from multiprocessing import Processimport os, time  # I/0密集型任务def work(): time.sleep(5) # 阻塞两秒  if __name__ == "__main__": l = [] print("本机为", os.cpu_count(), "核 CPU") start = time.time() for i in range(1000):  p = Process(target=work) # 多进程  l.append(p)  p.start() for p in l:  p.join() stop = time.time() print("I/0密集型任务,多进程耗时 %s" % (stop - start))

使用多线程(4核cpu)

from threading import Threadimport os, time  # I/0密集型任务def work(): time.sleep(5) # 阻塞两秒  if __name__ == "__main__": l = [] print("本机为", os.cpu_count(), "核 CPU") start = time.time()  for i in range(1000):  p = Thread(target=work) # 多线程  l.append(p)  p.start() for p in l:  p.join() stop = time.time() print("I/0密集型任务,多线程耗时 %s" % (stop - start))

输出:

本机为 64 核 CPU
I/0密集型任务,多进程耗时 12.28218412399292
 
 
本机为 64 核 CPU
I/0密集型任务,多线程耗时 5.399136066436768

说明:python的多线程有于GIL锁的存在,无论是多少核的cpu机器,也只能使用单核,从输出结果来看,对于IO密集型任务使用多线程比较占优。

FAQ:执行多进程的io密集型任务时,报了一个错:

OSError: [Errno 24] Too many open files

原因:linux系统限制

ulimit -n# 输出 1024

解决:(临时提高系统限制,重启后失效)

ulimit -n 10240

以上是“Python多进程与多线程的使用场景有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python多进程与多线程的使用场景有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python多进程与多线程的使用场景有哪些

这篇文章主要介绍Python多进程与多线程的使用场景有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言Python多进程适用的场景:计算密集型(CPU密集型)任务Python多线程适用的场景:IO密集型任务计算
2023-06-07

java多线程有哪些使用场景

这期内容当中小编将会给大家带来有关java多线程有哪些使用场景,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java有哪些集合类Java中的集合主要分为四类:1、List列表:有序的,可重复的;2、Que
2023-06-14

java多线程的使用场景有哪些

Java多线程的使用场景有很多,以下是几个常见的场景:1. 并发处理:当需要同时处理多个任务时,可以使用多线程来提高处理效率。例如,在服务器端处理多个客户端请求,或者在一个任务中同时进行多个计算。2. GUI应用程序:在图形用户界面(GUI
2023-08-15

java多线程应用场景有哪些

Java多线程的应用场景有以下几种:1. 任务并行:当一个任务可以被分解为多个独立的子任务,并且这些子任务可以并行执行时,可以使用多线程来提高程序的执行效率。例如,大规模数据的排序、并行计算等。2. 事件驱动:当需要同时处理多个事件或请求时
2023-09-13

C++多线程的应用场景有哪些

C++多线程的应用场景包括但不限于以下几个方面:1. 并发处理:多线程可以用于同时执行多个任务,提高程序的并发处理能力。例如,可以用多线程处理网络请求、数据库操作等耗时的任务,从而提高程序的响应速度。2. 并行计算:多线程可以将一个大型计算
2023-09-21

android多线程的应用场景有哪些

Android多线程的应用场景主要有以下几个:1. 后台任务处理:Android应用通常需要在后台执行一些耗时的任务,如网络请求、数据库操作等。使用多线程可以将这些任务放在后台线程中执行,以避免阻塞UI线程,提高用户体验。2. 异步任务处理
2023-09-12

Python多线程和多进程在什么场景中使用

这篇文章主要介绍“Python多线程和多进程在什么场景中使用”,在日常操作中,相信很多人在Python多线程和多进程在什么场景中使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python多线程和多进程在什
2023-06-16

JS多线程API webworker应用场景有哪些

这篇文章主要介绍了JS多线程API webworker应用场景有哪些,加密数据,预取数据,预渲染,复杂数据处理场景,预加载图片需要的朋友可以参考下
2023-02-18

Java中线程池的使用场景有哪些

今天就跟大家聊聊有关Java中线程池的使用场景有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 一、如下方式存在的问题new Thread() { @Override
2023-06-16

python中多进程与多线程有什么区别

python中多进程与多线程有什么区别?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。python的数据类型有哪些?python的数据类型:1. 数字类型,包括int(整型)、l
2023-06-14

linux中多进程和多线程的区别有哪些

这篇“linux中多进程和多线程的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“linux中多进程和多线程的区别有
2023-06-26

python中下划线的使用场景有哪些

python中下划线的使用场景有哪些?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、_用于临时变量单下划线一般用于表示临时变量,在REPL、for循环和元组拆包等场景中比
2023-06-15

Java多态的应用场景有哪些

Java多态的应用场景有以下几个:1. 方法重写:通过子类继承父类并重写父类的方法,可以根据实际对象的类型调用相应的方法,实现不同对象的不同行为。2. 方法重载:在同一个类中,可以定义多个同名但参数列表不同的方法,通过传递不同的参数来调用不
2023-09-22

php协程的使用场景有哪些

PHP协程的使用场景包括:高并发服务器:协程可以帮助提高PHP服务器的并发能力,减少服务器资源的消耗。例如,可以使用协程来处理大量的并发请求,而无需为每个请求创建一个独立的线程或进程。异步I/O操作:协程可以用于处理异步I/O操作,例如数据
2023-10-22

python中多进程和多线程的使用方法

这篇文章主要介绍了python中多进程和多线程的使用方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。进程和线程进程是系统进行资源分配的最小单位,线程是系统进行调度执行的最小
2023-06-14

php多线程与并发线程的区别有哪些

PHP是一种脚本语言,不支持真正的多线程,但可以通过多进程和协程来实现类似多线程的并发操作。并发性:多线程是指在一个程序中同时运行多个线程,每个线程执行不同的任务。并发线程是指在一个程序中同时执行多个线程,每个线程可以是同一个任务的不同实例
2023-10-23

c#使用多线程的方式有哪些

在C#中,有多种方式可以使用多线程:1. 使用Thread类:可以通过创建Thread对象,并将一个方法或委托分配给它的Start方法来创建一个新线程。例如:```csharpThread thread = new Thread(SomeM
2023-08-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录