python从入门到放弃之进程进阶篇
什么我们得了解清楚什么是进程,进程就是系统分配的一个资源单位,真正在程序中干活得是线程,默认是每个进程中都拥有一个线程
然后我们在了解下什么是进程池这个概念
进程池是的数量是取决于我当前电脑的逻辑处理器此时我们程序是异步并发的程序(即多个CPU同时执行多个任务)而我们之前学的进程下面创建子进程是异步并行的程序(即一个CPU执行多个任务)这既是两者之间的差别
Process 和 Pool 区别:
Process : 属于异步并发程序,主进程会默认等待子进程全部执行完毕之后,在终止程序
Pool : 属于异步并行程序,在没有任何阻塞的情况下,只要主进程执行完毕,会立刻终止所有子进程;
p = Pool(6):
代表同一时间最多允许并行6个进程;
进程池pool里面的参数
如果Pool不加任何参数,默认使用的是os.cpu_count()获取到的数量 逻辑处理器
如果加了参数,就使用当前参数值,所代表的是同一时间最大允许的进程数(并行)
在进程池中,如果一个进程执行任务的速度太快,会包揽更多的任务执行,就不会创建新的进程;
# (1) 比较进程池和进程之间的速度 => 进程池速度更快
1 def func(num):
2 print(os.getpid())
3 # print(num)
4 # time.sleep(0.1)
5 for i in range(1000000):
6 pass
7 # 27612 27524 25940 26448 27520 26204
8 if __name__ == "__main__":
9 # 记录开始时间
10 startime = time.time()
11 # 1.创建进程池
12 p = Pool(6)
13 for i in range(100):
14 # 2.异步并行执行进程
15 p.apply_async(func,args=(i,))
16 # 3.关闭进程池
17 p.close()
18 # 4.等待子进程全部执行结束之后,在向下执行
19 p.join()
20 # 记录结束时间
21 endtime = time.time()
22 print("1号运行的时间是:",endtime-startime) # 0.5326602458953857
23 print("进程池运行结束 ... ")
24
25 # 计算process运行的时间
26 startime = time.time()
27 lst = []
28 for i in range(100):
29 p = Process(target=func,args=(i,))
30 p.start()
31 lst.append(p)
32
33 for i in lst:
34 i.join()
35 endtime = time.time()
36 print("2号运行的时间是:",endtime-startime) # 2.051966428756714
37 print("process运行结束 ..")
# 旧版进程池,主进程执行结束后,立刻终止子进程;
def func(num):
print(os.getpid()) if __name__ == "__main__": # .创建进程池
p = Pool()
for i in range():
# .异步并行执行进程
p.apply_async(func,args=(i,))
# .关闭进程池
p.close()
# .等待子进程全部执行结束之后,在向下执行
p.join() print("进程池运行结束 ... ")
# (2) apply 同步程序,可以直接获取子进程中的返回值(了解)
def task(num):
print("num:%s 进程号%s"%(num,os.getpid()))
return os.getpid() if __name__ == "__main__":
# 同一时间最多运行并行4个进程
p = Pool()
for i in range():
res = p.apply(task,args=(i,))
print(">>>",res)
print(" 主程序执行结束 ... ")
# (3) apply_async 异步程序 , 可以直接通过get获取子进程中的返回值
def task(num):
time.sleep(random.uniform(0.1,1))
# print("num:%s 进程号%s"%(num,os.getpid()))
return os.getpid() if __name__ == "__main__":
lst = []
setvar = set()
p = Pool()
for i in range(20):
res = p.apply_async(task,args=(i,))
lst.append(res) # print(lst)
for i in lst:
# 用来获取当前子进程的返回值 get函数本身含有阻塞,不加close和join一样可以
res = i.get()
# print(res)
setvar.add(res) print(setvar) # {28136, 25480, 20472, 28012, 27344, 24984} # 3.关闭进程池
# p.close()
# 4.等待子进程全部执行结束之后,在向下执行
# p.join() print("finish")
# (4) map (与高阶函数map使用方法一样,区别在于并发和并行) 返回列表
def task(num):
print("num:%s 进程号%s"%(num,os.getpid()))
time.sleep(0.1)
return num ** 2 if __name__ == "__main__":
p = Pool()
res = p.map(task,range(100))
print(res)
print("主进程 finish")
# (5) close 和 join 同时使用,或者同时不适用,必须是一对
def task(num):
# print("num:%s 进程号%s"%(num,os.getpid()))
# time.sleep(0.1)
return num ** 2
if __name__ == "__main__":
lst = []
p = Pool()
for i in range(20):
# res 返回的是异步的进程对象
res = p.apply_async(task,args=(i,))
lst.append(res)
"""
for i in lst:
# 在获取返回值的同时,加了阻塞
print(i.get())
"""
# 关闭进程池
p.close()
# p.apply_async(task,args=(100))
p.join()
print("主进程 finish")
python从入门到放弃之进程进阶篇的更多相关文章
- python从入门到放弃之进程
在理解进程之前我们先了解一下什么是进程的概念吧 以下就是我总结的一些基本的进程概念 进程就是正在运行的程序,它是操作系统中,资源分配的最小单位(通俗易懂点也就是电脑给程序分配的一定内存操作空间).资源 ...
- python从入门到放弃之进程锁lock
# ### lock (互斥锁)"""# 应用在多进程当中# 互斥锁lock : 互斥锁是进程间的get_ticket互相排斥进程之间,谁先抢占到资源,谁就先上锁,等到解 ...
- [Python 从入门到放弃] 6. 文件与异常(二)
本章所用test.txt文件可以在( [Python 从入门到放弃] 6. 文件与异常(一))找到并自行创建 现在有个需求,对test.txt中的文本内容进行修改: (1)将期间的‘:’改为‘ sai ...
- [Python 从入门到放弃] 1. 列表的基本操作
''' 列表 Create By 阅后即焚 On 2018.1.29 ''' 1. 列表的定义 列表看起来好像其它编程语言中的数组,但列表具备更加强大的功能,它是Python完备的集合对象,现在,你可 ...
- Python 学习入门(23)—— 进程
本文介绍Python的os包中有查询和修改进程信息的函数,Python的这些工具符合Linux系统的相关概念,所以可以帮助理解Linux体系. 1. 进程信息 os包中相关函数如下: uname() ...
- Python从入门到放弃系列(Django/Flask/爬虫)
第一篇 Django从入门到放弃 第二篇 Flask 第二篇 爬虫
- python全栈开发从入门到放弃之函数进阶
1.三元运算 a= 1 b=2 max = (a if a>b else b ) #条件成立的结果 if 条件 else 条件不成立的结果 print(max) 2.先上一首python之禅 i ...
- python从入门到放弃--线程进阶
# ### 死锁,递归锁,互斥锁 from threading import Thread,Lock import time noodle_lock = Lock() kuaizi_lock = Lo ...
- python从入门到放弃之守护进程
# ### 守护进程 默认情况下,主进程要等待所有子进程执行完毕之后,才会关闭程序,释放资源守护进程进行在主进程代码执行结束之后,就直接关闭;守护进程守护的是主进程 语法: 进程.daemon = T ...
随机推荐
- [PHP] 深度解析Nginx下的PHP框架路由实现
所有的框架处理业务请求时,都会处理URL的路径部分,分配到指定的代码中去处理.实现这一功能的关键就是获取$_SERVER全局变量中对于URL部分的数据 当请求的路径为http://test.com/a ...
- WindowsServer2003中IIS支持php的配置
1.安装MySQL(没有特殊说明的就按照默认安装)选择 Custom 自定义安装点击"Change"更改 MySQL 安装目录(自定义)其他按照默认的下一步就可以 安装完成后会自动 ...
- JDBC API浅析
使用java开发数据库应用程序一般都需要用到四个接口:Driver.Connection.Statement.ResultSet 1.Driver接口用于加载驱动程序 2.Connection接口用于 ...
- 7.3 DStream操作
一.Spark Streaming工作机制 在Spark Streaming中,会有一个组件Receiver,作为一个长期运行的task跑在一个Executor上: 每个Receiver都会负责一个i ...
- CSS百分比padding实现比例固定图片自适应布局
一.CSS百分比padding都是相对宽度计算的 在默认的水平文档流方向下,CSS margin和padding属性的垂直方向的百分比值都是相对于宽度计算的,这个和top, bottom等属性的百分比 ...
- NOIP模拟赛2(two)
题目描述 Description 很久很久很久以前,方方方造了一台计算机,计算机中开始有一个数 \(0\) .方方方想要让这个数变成 \(a\) ,他打算每次选择一个整数,把计算机中当前的数按位或上这 ...
- [学习笔记] 舞蹈链(DLX)入门
"在一个全集\(X\)中若干子集的集合为\(S\),精确覆盖(\(\boldsymbol{Exact~Cover}\))是指,\(S\)的子集\(S*\),满足\(X\)中的每一个元素在\( ...
- QFramework 学习
github地址: https://github.com/liangxiegame/QFramework 框架官网: http://qf.liangxiegame.com/ 视频教程: http:// ...
- Paper | Densely Connected Convolutional Networks
目录 黄高老师190919在北航的报告听后感 故事背景 网络结构 Dense block DenseNet 过渡层 成长率 瓶颈层 细节 实验 发表在2017 CVPR. 摘要 Recent work ...
- 动态修改maven的jdk版本
当环境变量jdk为1.7,项目为jdk1.8,用mvn clean package指令打包项目时,想不修改环境变量的情况下,修改maven的jdk版本 方法如下: 官网给出了方法 https://ma ...