gpt4 book ai didi

python - python能够在多核上运行吗?

转载 作者:IT老高 更新时间:2023-10-28 20:25:36 33 4
gpt4 key购买 nike

问题:由于 python 使用“GIL”,python 是否能够同时运行其单独的线程?


信息:

看完this我不确定python是否能够利用多核处理器。像python一样出色,想到它会缺乏如此强大的能力,感觉真的很奇怪。所以感觉不确定,我决定在这里问。如果我编写一个多线程的程序,它是否能够在多个内核上同时执行?

最佳答案

答案是“是的,但是……”

但是当您使用常规线程进行并发时,cPython 不能。

您可以使用 multiprocessing 之类的内容, celerympi4py将并行工作拆分为另一个进程;

或者你可以使用类似 JythonIronPython使用没有 GIL 的替代解释器。

更温和的解决方案是使用不与 GIL 冲突的库来处理繁重的 CPU 任务,例如 numpy可以在不保留 GIL 的情况下完成繁重的工作,因此其他 python 线程可以继续。您也可以使用 ctypes这样的图书馆。

如果您不进行 CPU 密集型工作,则可以完全(某种程度地)忽略 GIL 问题,因为 python 在等待 IO 时不会获取 GIL。

关于python - python能够在多核上运行吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7542957/

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