进程

from multiprocessing import Process
import time def start(name):
time.sleep(1)
print('hello', name) if __name__ == '__main__':
# 开辟一个进程
p = Process(target=start, args=('zhangsan',))
# 再开辟一个进程
p1 = Process(target=start, args=('lisi',))
p.start()
p1.start()
p.join()

进程间通讯,每个进程都有自己的内存空间,因此不同进程内存是不共享的,要想实现两个进程间的数据交换,有几种方法

Queue(队列)

def start(q):
q.put('hello') if __name__ == '__main__':
q = Queue()
p = Process(target=start, args=(q,))
p.start()
print(q.get())
p.join()

Pipe(管道)

把管道的两头分别赋给两个进程,实现两个进程的互相通信

def start(left_conn):
right_conn.send('你好') # 发送
print(right_conn.recv()) # 接收
right_conn.close() if __name__ == '__main__':
left_conn, right_conn = Pipe() # 生成管道
p = Process(target=start, args=(right_conn,))
p.start()
print(left_conn.recv()) # 接收
left_conn.send('你也好') # 发送
p.join()

左管道发送,右管道接收,随后右管道返回消息,左管道接收,关闭管道

Manager实现了进程间真正的通信共享


from multiprocessing import Process, Manager def f(dic, i):
dic[i] = i
if __name__ == '__main__':
manager = Manager()
dic = manager.dict() # 通过manager生成一个字典
p_list = []
for i in range(10):
p = Process(target=f, args=(dic, i))
p.start()
p_list.append(p)
# 等待所有进程执行完毕
for res in p_list:
res.join()
print(dic)

进程池

进程池内部维护一个进程序列,当使用时,则去进程池获取一个进程,如果进程池序列中没有可以使用的进程,那么程序就会等待,直到进程池中有可用进程为止。

from multiprocessing import Process, Pool
import time def Foo(i): return i + 100 def Bar(arg):
print('number:', arg) if __name__ == '__main__':
pool = Pool(3) # 定义一个进程池,里面有3个进程
for i in range(10):
# callback是回调函数,就是在执行完Foo方法后会自动执行Bar函数,并且会把Foo函数的返回值作为参数传入Bar参数
pool.apply_async(func=Foo, args=(i,), callback=Bar)
# 必须先关闭进程池,在关闭进程池中的进程
pool.close()
# 等待进程池中的进程结束后关闭
pool.join()

程序会一次拿出来三个从池子里,直到没有

from greenlet import greenlet
import time
def test1():
print('---aaa---')
time.sleep(1)
gr2.switch()
print('---bbb---')
time.sleep(1)
gr2.switch() def test2():
print('-----ccc-----')
time.sleep(1)
gr1.switch()
print('-----ddd-----')
while 1:
gr1 = greenlet(test1)
gr2 = greenlet(test2)
gr1.switch()

协程

微线程,协程能保留上次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态。

协程有极高的执行效率,因为子程序切换不是线程切换,而是自身控制,因此,没有线程切换的开销。

不需要多线程的锁机制,因为它本身只有一个线程,只需要判断状态就好,所以效率高

因为协程是一个线程进行,所以想要利用多核CPU,就是多进程加协程

符合协程的条件:

  1. 必须在只有一个单线程里并发
  2. 修改共享数据不需要加锁
  3. 用户程序里自己保存多个控制流的上下文
  4. 一个协程遇到IO操作自动切换到其他协程

python的两个协程模块:

  • greenlet(执行顺序需要手动控制)
from greenlet import greenlet
import time
def test1():
print('---aaa---')
time.sleep(1)
gr2.switch()
print('---bbb---')
time.sleep(1)
gr2.switch() def test2():
print('-----ccc-----')
time.sleep(1)
gr1.switch()
print('-----ddd-----')
while 1:
gr1 = greenlet(test1)
gr2 = greenlet(test2)
print('开始启动')
gr1.switch()

手动切换协程,当运行到aaa,切换到ccc,再次切换回去,并且会记录上一次执行完aaa的位置,会从bbb开始执行,如此循环下去,就会出现如下图所示的结果

Python中的进程的更多相关文章

  1. python中的进程、线程(threading、multiprocessing、Queue、subprocess)

    Python中的进程与线程 学习知识,我们不但要知其然,还是知其所以然.你做到了你就比别人NB. 我们先了解一下什么是进程和线程. 进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CP ...

  2. python中的进程池

    1.进程池的概念 python中,进程池内部会维护一个进程序列.当需要时,程序会去进程池中获取一个进程. 如果进程池序列中没有可供使用的进程,那么程序就会等待,直到进程池中有可用进程为止. 2.进程池 ...

  3. python中的进程池:multiprocessing.Pool()

    python中的进程池: 我们可以写出自己希望进程帮助我们完成的任务,然后把任务批量交给进程池 进程池帮助我们创建进程完成任务,不需要我们管理.进程池:利用multiprocessing 下的Pool ...

  4. 第十五章、python中的进程操作-开启多进程

    目录 第十五章.python中的进程操作-开启多进程 一.multprocess模块 二.multprocess.process模块 三.Process()对象方法介绍 四.Process()对象属性 ...

  5. Python中的进程池与线程池(包含代码)

    Python中的进程池与线程池 引入进程池与线程池 使用ProcessPoolExecutor进程池,使用ThreadPoolExecutor 使用shutdown 使用submit同步调用 使用su ...

  6. Python 中的进程、线程、协程、同步、异步、回调

    进程和线程究竟是什么东西?传统网络服务模型是如何工作的?协程和线程的关系和区别有哪些?IO过程在什么时间发生? 一.上下文切换技术 简述 在进一步之前,让我们先回顾一下各种上下文切换技术. 不过首先说 ...

  7. Python 中的进程与 锁

    理论知识 操作系统背景知识 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操 ...

  8. 深入理解Python中的进程

    1.进程的概念什么是进程—>CPU在同一时刻只能处理一个任务,只是因为cpu执行速度很快. cpu在各个任务之间来回的进行切换. 进程的概念:正在进行的一个过程或者说一个任务,而负责执行任务的则 ...

  9. python中的进程池和线程池

    Python标准模块-concurrent.futures #1 介绍 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor:线程池,提供异步调用 ...

随机推荐

  1. python基础知识15---三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数

    阅读目录 一 三元表达式.列表推导式.生成器表达式 二 递归与二分法 三 匿名函数 四 内置函数 五 阶段性练习 一. 三元表达式.列表推导式.生成器表达式 1 三元表达式 name=input('姓 ...

  2. ObjectARX2012+ObjectARX Wizards2012+AutoCAD2012+MVS2008 环境配置

    1  版本选择 ObjectARX本身采用的MVS编译平台,因此选择ObjectARX的编译平台作为二次开发的平台,兼容性最好,当然别的平台也不是一定不可以.目前已知的对应关系如下: R15   -- ...

  3. crf++实现中文分词简单例子 (Windows crf++0.58 python3)

    学习自然语言处理的同学都知道,条件随机场(crf)是个好东西.虽然它的原理确实理解起来有点困难,但是对于我们今天用到的这个crf工具crf++,用起来却是挺简单方便的. 今天只是简单试个水,参考别人的 ...

  4. 二、初步认识springBoot的pom.xml

    1.  大体结构 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www. ...

  5. Linux 版 SecureCRT 界面变为 Windows 2000 风格的解决办法

    SecureCRT 是一款非常好用的远程终端连接软件,支持 Windows.Linux.macOS 全平台.由于现在工作平台主要在 Linux 系统上,SecureCRT 也是必备软件.一开始安装的是 ...

  6. freemarker数据类型

    基本数据类型: 字符串 数字 布尔值 日期/时间 (日期,时间或日期时间) 数据结构: 哈希表 序列 注意一点:freemarker里面并没有对象这一数据类型!!!. 在freemarker中对象仅仅 ...

  7. Android几种视频播放方式,VideoView、SurfaceView+MediaPlayer、TextureView+MediaPlayer,以及主流视频播放器开源项目

    简单的说下一Android的几种视频播放功能: 1.VideoView:最简单的视频播放 <FrameLayout xmlns:android="http://schemas.andr ...

  8. Java 公平锁与非公平锁学习研究

    最近学习研究了一下Java中关于公平锁与非公平锁的底层实现原理,总结了一下. 首先呢,通过其字面意思,公平与非公平的评判标准就是付出与收获成正比(和社会中的含义差不多一个意思).放到程序中,尤其是 在 ...

  9. leetcode每日刷题计划-简单篇day11

    Num 121 买卖股票的最佳时期 Best Time to Buy and Sell Stock class Solution { public: int maxProfit(vector<i ...

  10. python自动化,使用unittest对界面操作,读取excel表格数据输入到页面查询结果,在把结果保存到另外一张excel中

    # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom ...