为啥我的信号量程序打印 20 秒而不是 10 秒?

Posted

技术标签:

【中文标题】为啥我的信号量程序打印 20 秒而不是 10 秒?【英文标题】:Why my program with semaphore prints 20 secs instead of 10 secs?为什么我的信号量程序打印 20 秒而不是 10 秒? 【发布时间】:2021-12-19 18:07:50 【问题描述】:

以下是我的主要项目中的简化程序。我使用Semaphore 只允许两个进程一次执行test 函数。如果我不是疯了,程序应该只有 10 秒的运行时间,但我有 20 秒。如何修复它以将我的程序运行时间减少到 10 秒?

注意:在 Windows 10 上使用 Sublime 测试。

import time
from multiprocessing import Semaphore, Lock, Process

def test(sem):
    sem.acquire()
    time.sleep(5)
    sem.release()

if __name__ == '__main__':
    sem = Semaphore(2)
    processes = []
    
    for _ in range(4):
        processes.append(Process(target=test, args=(sem,)))

    start = time.perf_counter()
    
    for process in processes:
        process.start()
        process.join()

    end = time.perf_counter() - start

    print(f'program finished in end secs')

输出

program finished in 20.836512662 secs
[Finished in 21.1s]

【问题讨论】:

process.join() 正在等待当前进程结束...在启动第二个等之后...然后等待 5,5,5,5 【参考方案1】:
for process in processes:
        process.start()
        process.join()

您正在启动每个进程,然后立即等待它完成。

这是 4 个进程,每个进程等待 5 秒。因此 20 秒。您的代码中没有实际的并行性。

您想要的是同时启动所有进程。然后等待每个完成:

for process in processes:
        process.start()  # start each
for process in processes:
        process.join()   # wait for all to finish

结果:

program finished in 10.129543458 secs

【讨论】:

以上是关于为啥我的信号量程序打印 20 秒而不是 10 秒?的主要内容,如果未能解决你的问题,请参考以下文章

如何等待 10 秒而不锁定 android 中的应用程序 UI [重复]

更改 addMouseCoordinates 以显示十进制分钟秒而不是十进制度?

炮弹模拟

PHP 请求“排队”

AdLds / Adam 每 50 秒卡住一次

为啥打印结果与实物不符