gpt4 book ai didi

python - 锁定多处理包不起作用

转载 作者:行者123 更新时间:2023-11-30 23:32:49 25 4
gpt4 key购买 nike

以下代码非常简单,仅用于测试目的,但我没有得到所需的输出:

from multiprocessing import Process,Lock

def printing(l,i):
l.acquire()
print i
l.release()

if __name__ == '__main__':
lock = Lock()

for i in range(10):
Process(target=printing,args=(lock,i)).start()

输出为:

0
1
2
3
5
6
4
7
8
9

锁应该暂停其他进程的执行。为什么这里没有发生这种情况?

最佳答案

您期望什么输出?输出对我来说看起来不错:range(10) 的排列。进程执行的顺序可能因运行而异。这是预期的结果。

我怀疑你误解了锁的作用。当您获取锁时,所有其他尝试获取相同锁的进程都会阻塞,直到锁被释放。就这样。在您的测试运行中,进程 0 碰巧首先获取了锁。任何其他尝试获取锁的进程都会被阻塞,直到进程 0 释放锁。进程 0 打印 0 然后释放锁。然后恰巧进程1获得了锁。等等

注释掉你的l.release(),你会发现你的程序永远不会完成:第一个恰好获取锁的进程然后打印它的整数,所有其他进程永远不会结束阻塞等待获取锁。

关于python - 锁定多处理包不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19212491/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com