python为什么安全_为什么Python多处理管道不安全?

博客围绕Python多进程编程展开,提出当存在多个发送者和接收者时为何被称为不安全的疑问。还探讨了Queues关闭不抛EOFError导致进程无法停止的问题,以及如何让管道一直打开。并给出了多进程管道通信的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我不明白为什么当存在多个发送者和接收者时^{}被称为不安全。

如果是这样,如何使用^{}将以下代码转换为代码?Queues关闭时不要抛出EOFError,因此我的进程无法停止。我是否应该不断地发送“毒药”消息,告诉他们停止(这样,我确信我的所有进程都至少收到一种毒药)?

我想让管道p1一直打开,直到我决定不打开为止(这里是我发送10条消息的时间)。from multiprocessing import Pipe, Process

from random import randint, random

from time import sleep

def job(name, p_in, p_out):

print(name + ' starting')

nb_msg = 0

try:

while True:

x = p_in.recv()

print(name + ' receives ' + x)

nb_msg = nb_msg + 1

p_out.send(x)

sleep(random())

except EOFError:

pass

print(name + ' ending ... ' + str(nb_msg) + ' message(s)')

if __name__ == '__main__':

p1_in, p1_out = Pipe()

p2_in, p2_out = Pipe()

proc = []

for i in range(3):

p = Process(target=job, args=(str(i), p1_out, p2_in))

p.start()

proc.append(p)

for x in range(10):

p1_in.send(chr(97+x))

p1_in.close()

for p in proc:

p.join()

p1_out.close()

p2_in.close()

try:

while True:

print(p2_out.recv())

except EOFError:

pass

p2_out.close()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值