首页 / 知识
python 管道
2023-11-12 13:31:00
创建管道的类:
Pipe([duplex]):在进程之间创建一条管道,并返回元组(conn1,conn2),其中conn1,conn2表示管道两端的连接对象,强调一点:必须在产生Process对象之前产生管道
参数介绍:
dumplex:默认管道是全双工的,如果将duplex射成False,conn1只能用于接收,conn2只能用于发送。
frommultiprocessingimportProcess,Pipe
importtime,os
defconsumer(p,name):
left,right=p
left.close()
whileTrue:
try:
baozi=right.recv()
print('%s收到包子:%s'%(name,baozi))
exceptEOFError:
right.close()
break
defproducer(seq,p):
left,right=p
right.close()
foriinseq:
left.send(i)
#time.sleep(1)
else:
left.close()
if__name__=='__main__':
left,right=Pipe()
c1=Process(target=consumer,args=((left,right),'c1'))
c1.start()
seq=(iforiinrange(10))
producer(seq,(left,right))
right.close()
left.close()
c1.join()
print('主进程')
注意:生产者和消费者都没有使用管道的某个端点,就应该将其关闭,如在生产者中关闭管道的右端,在消费者中关闭管道的左端。如果忘记执行这些步骤,程序可能再消费者中的recv()操作上挂起。管道是由操作系统进行引用计数的,必须在所有进程中关闭管道后才能生产EOFError异常。因此在生产者中关闭管道不会有任何效果,付费消费者中也关闭了相同的管道端点。
管道可以用于双向通信,利用通常在客户端/服务器中使用的请求/响应模型或远程过程调用,就可以使用管道编写与进程交互的程序
frommultiprocessingimportProcess,Pipe
importtime,os
defadder(p,name):
server,client=p
client.close()
whileTrue:
try:
x,y=server.recv()
exceptEOFError:
server.close()
break
res=x+y
server.send(res)
print('serverdone')
if__name__=='__main__':
server,client=Pipe()
c1=Process(target=adder,args=((server,client),'c1'))
c1.start()
server.close()
client.send((10,20))
print(client.recv())
client.close()
c1.join()
print('主进程')
#注意:send()和recv()方法使用pickle模块对对象进行序列化。
以上内容为大家介绍了python管道,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注我们
最新内容
相关内容
Python学习之进程和线程
Python学习之进程和线程,代码,平台,系统,线程,进程,标准,数据,服务,培训,管理,对于操作系统来说,一个任务就是一个进程(Process),比如打开一个Pytorch入门之配置云服务器环境
Pytorch入门之配置云服务器环境,环境,平台,流程,代码,数据,工具,平稳,网络,时间,网上,Pytorch简介Pytorch底层是Torch框架,Torch框架是一个科Python进程、线程、协程的区别
Python进程、线程、协程的区别,地址,单位,线程,入口,状态,培训,进程,区别,资源,空间,简述进程、线程、协程的区别以及应用场景?线程是指进程python的错误和异常
python的错误和异常,异常,代码,地方,标准,官网,状态,第三,第一,时间,培训,python至少有2类不同的错误:语法错误(SyntaxErrors)和异常(Exceptiopython 进程间通信
python 进程间通信,数据,项目,生产,通信,通讯,队列,生产者,培训,异常,进程,虽然可以用文件共享数据实现进程间通信,但问题是:1)效率低(共享数据python多线程和多进程之间的联系
python多线程和多进程之间的联系,进程,培训,通信,标准,管理,代理,线程,模块,之间,全部,关于多线程的大概讲解:在Python的标准库中给出了2个模python如何写多进程
python如何写多进程,培训,进程,方法,对象,线程,测试,个子,函数,实例,差不多,python中的多进程是通过multiprocessing包来实现的,和多线程的thrpython怎么抛出异常不乱码
python怎么抛出异常不乱码,异常,代码,信息,基础,检测,培训,语句,发生,程序,乱码,当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执python出错时怎么抛出异常
python出错时怎么抛出异常,异常,代码,信息,基础,检测,培训,语句,发生,程序,结束,基础异常处理try/except语句用来检测try语句块中的错误,从而python怎么处理错误和异常
python怎么处理错误和异常,异常,代码,培训,情况,位置,错误,发生,文件,程序,语句,异常当你的程序出现例外情况时就会发生异常(Exception)。例python 培训之 object是什么类型
python 培训之 object是什么类型,培训,类型,实例,顶端,对象,关系,链条,父子,数据类型,属性,在Python的世界中,object是父子关系的顶端,所有的数python怎么抛出异常信息
python怎么抛出异常信息,异常,代码,信息,基础,检测,培训,语句,发生,程序,除数,当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行