AI实践:如何应用多进程Multiprocessing编程?
citgpt 2024-09-09 02:17 10 浏览 0 评论
欢迎大家关注我,一起学习~
multiprocessing和threading:
多线程 threading:计算机同一时间还是只能处理一个线程
多核 multiprocessing:现在计算机都有多核处理器,将任务分给多个核来处理,他们有单独的运算空间和计算能力,避免了多线程的劣势。
导入包:
定义一个被线程和进程调用的函数
创建进程和线程
Queue功能:
Queue的功能是将每个核或线程的运算结果放在队里中, 等到每个线程或核运行完毕后再从队列中取出结果, 继续加载运算。原因很简单, 多线程调用的函数不能有返回值, 所以使用Queue存储多个线程运算的结果
定义一个被多线程调用的函数,q就像一个队列,用来保存每次函数运行的结果
主函数:
效率比较:多线程、多进程、普通的消耗时间;
实际时间对比:
运行时间是 多进程 < 普通 < 多线程
进程池就是我们将所要运行的东西,放到池子里,Python会自行解决多进程的问题。
导入包并定义函数:
有了池子之后,就可以让池子对应某一个函数,向池子里输入数据,池子就会返回函数返回的值。
Pool和之前的Process的不同点是丢向Pool的函数有返回值,而Process的没有返回值。
接下来用map()获取结果,在map()中需要放入函数和需要迭代运算的值,然后它会自动分配给CPU所有核,返回结果。
除了map()函数,Pool还有apply_async()函数可以返回结果。apply_async()中只能传递一个值,只会放入一个核进行运算,传入值时要注意是可迭代的,所以在传入值后需要加逗号。
如何用apply_async()输出多个迭代呢?多传入几个值试试~
合并代码:
可以看出在apply用迭代器的得到的结果和用map得到的结果是一样的
总结
1. Pool默认调用是CPU的核数,传入processes参数可自定义CPU核数
2. map() 放入迭代参数,返回多个结果
3. apply_async()只能放入一组参数,并返回一个结果,如果想得到map()的效果需要通过迭代。
只有用共享内存才能让CPU之间有交流。
Shared Value:(多线程中global value)
多进程,即使传入global 变量,多进程中也无法交流,我们可以通过使用Value数据存储在一个共享的内存表中。
Shared Array:(仅仅是一个一维列表)
这里的Array和numpy中的不同,它只能是一维的,不能是多维的。
同样和Value 一样,需要定义数据形式,否则会报错。
参考数据形式
各参数代表的数据类型
进程锁的运用:使进程之间不会互相干扰
不加进程锁
在上面的代码中,我们定义了一个共享变量v,两个进程都可以对它进行操作。 在job()中我们想让v每隔0.1秒输出一次累加num的结果,但是在两个进程p1和p2 中设定了不同的累加值。所以接下来让我们来看下这两个进程是否会出现冲突。
运行一下:
145891213161720
我们可以看到,进程1和进程2在相互抢着使用共享内存v。
加进程锁
为了解决上述不同进程抢共享资源的问题,我们可以用加进程锁来解决。
首先需要定义一个进程锁
然后将进程锁的信息传入各个进程中
在job()中设置进程锁的使用,保证运行时一个进程的对锁内内容的独占
完整代码:
运行一下,让我们看看是否还会出现抢占资源的情况:
12345811141720
显然,进程锁保证了进程p1的完整运行,然后才进行了进程p2的运行
参考自:莫烦python https://morvanzhou.github.io/tutorials/python-basic/multiprocessing/
为了更方便管理文章,同名微信公众号已经上线,喜欢使用微信的朋友们,欢迎大家关注!
相关推荐
- js中arguments详解
-
一、简介了解arguments这个对象之前先来认识一下javascript的一些功能:其实Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载。Javascrip中每个函数...
- firewall-cmd 常用命令
-
目录firewalldzone说明firewallzone内容说明firewall-cmd常用参数firewall-cmd常用命令常用命令 回到顶部firewalldzone...
- epel-release 是什么
-
EPEL-release(ExtraPackagesforEnterpriseLinux)是一个软件仓库,它为企业级Linux发行版(如CentOS、RHEL等)提供额外的软件包。以下是关于E...
- FullGC详解 什么是 JVM 的 GC
-
前言:背景:一、什么是JVM的GC?JVM(JavaVirtualMachine)。JVM是Java程序的虚拟机,是一种实现Java语言的解...
-
2024-10-26 08:50 citgpt
- 跨域(CrossOrigin)
-
1.介绍 1)跨域问题:跨域问题是在网络中,当一个网络的运行脚本(通常时JavaScript)试图访问另一个网络的资源时,如果这两个网络的端口、协议和域名不一致时就会出现跨域问题。 通俗讲...
- 微服务架构和分布式架构的区别
-
1、含义不同微服务架构:微服务架构风格是一种将一个单一应用程序开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制(通常用HTTP资源API)。这些服务围绕业务能力构建并...
- 深入理解与应用CSS clip-path 属性
-
clip-pathclip-path是什么clip-path 是一个CSS属性,允许开发者创建一个剪切区域,从而决定元素的哪些部分可见,哪些部分会被隐...
-
2024-10-25 11:51 citgpt
- Request.ServerVariables 大全
-
Request.ServerVariables("Url")返回服务器地址Request.ServerVariables("Path_Info")客户端提供的路...
- python操作Kafka
-
目录一、python操作kafka1.python使用kafka生产者2.python使用kafka消费者3.使用docker中的kafka二、python操作kafka细...
- Runtime.getRuntime().exec详解
-
Runtime.getRuntime().exec详解概述Runtime.getRuntime().exec用于调用外部可执行程序或系统命令,并重定向外部程序的标准输入、标准输出和标准错误到缓冲池。...
- promise.all详解 promise.all是干什么的
-
promise.all详解promise.all中所有的请求成功了,走.then(),在.then()中能得到一个数组,数组中是每个请求resolve抛出的结果...
-
2024-10-24 16:21 citgpt
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracleclient (56)
- springbatch (59)
- oracle恢复数据 (56)
- 简单工厂模式 (68)
- 函数指针 (72)
- fill_parent (135)
- java配置环境变量 (140)
- linux文件系统 (56)
- 计算机操作系统教程 (60)
- 静态ip (63)
- notifyicon (55)
- 线程同步 (58)
- xcode 4 5 (60)
- 调试器 (60)
- c0000005 (63)
- html代码大全 (61)
- header utf 8 (61)
- 多线程多进程 (65)
- require_once (60)
- 百度网盘下载速度慢破解方法 (72)
- 谷歌浏览器免费入口 (72)
- npm list (64)
- 网站打开速度检测 (59)
- 网站建设流程图 (58)
- this关键字 (67)