管道
先画一幅图帮助大家理解下管道的基本原理
现有2个进程A和B,他们都在内存中开辟了空间,那么我们在内存中再开辟一个空间C,作用是连接这两个进程的。对于进程来说内存空间是可以共享的(任何一个进程都可以使用内存,内存当中的空间是用地址来标记的,我们通过查找某一个地址就能找到这个内存)A进程可以不断的向C空间输送东西,B进程可以不断的从C空间读取东西,这就是进程间的通信
这个通信方式的原理类似于用文件通信,一个进程往文件里写,另外一个进程从文件里读取,最大的不同在于管道里C的空间是开辟在内存当中,第一是他不容易被截获,第二是进程结束后内存空间他会自动的释放掉,文件就不能自动释放掉。第三就是内存的传输是不需要和磁盘交互,所以相比文件管道的传输效率要高很多,这就是管道的基本原理。
管道在信息传输上是以流的方式传输, 也就是你从A进程不断的写入,B进程源源不断的读出,A进程先写入的就会被B进程先读出,后写进来的就会被后读出,管道不仅仅可以让A进程写C内存空间收,也可以B进程写,C内存空间收,也就是双向通信,单项通信叫做半双工,双向叫做全双工
2.管道本质
在内存中开辟一个新的空间,对多个进程可见,在通信形式上形成一种约束
3.创建管道
multiprocessing------------->Pipe
1.首先理解Pipe是什么,有人理解为类,那到底是什么?
>>> from multiprocessing import Pipe
>>> type(Pipe)
<class 'method'>
可以看到是个方法,也就是函数,是通过函数的返回值来完成工作的,不是类
2.下下来看具体事例:
import os,time from multiprocessing import Pipe,Process #进程函数 def func(name): time.sleep(1) print('父进程的id为:',os.getppid(),"--------",'子进程的id为:',os.getpid()) #创建五个进程 if __name__ == '__main__': job = [] for i in range(5): p = Process(target=func,args=(i,)) #把新的进程添加到列表里 job.append(p) p.start() for i in job: i.join()
&n