AYO_YO 2022-03-27 20:53 采纳率: 100%
浏览 116
已结题

Python程序运行在多核CPU上的问题

众所周知,Python由于历史遗留的GIL问题,不借助特殊的手段,是无法在多核上运行的。

于是写了一段多线程跑死循环,想验证一下:

import threading, multiprocessing

def loop():
    x = 0
    while True:
        x ^= 1
        print(x)

for i in range(multiprocessing.cpu_count()):
    t = threading.Thread(target=loop)
    t.start()

这一验证验证出问题了,通过性能监视发现,轻轻松松跑满了8个逻辑核。如下图

img

此时运行环境是Win 11,Python 3.10。然后我又换到WSL环境测试,Kali-Linux,Python 3.9.7,得到了一样的结论。。

img

是哪里出了问题?

  • 写回答

2条回答 默认 最新

  • ~白+黑 Python领域新星创作者 2022-03-28 08:47
    关注

    由于存在全局解释器锁,同一时刻只有一个线程可以执
    行 Python 代码(虽然某些性能导向的库可能会去除此限制)。如果你想让你的应用更好地利用多核心计算
    机的计算资源,推荐你使用multiprocessing 或concurrent.futures.ProcessPoolExecutor。
    但是,如果你想要同时运行多个 I/O 密集型任务,则多线程仍然是一个合适的模型。

    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月10日
  • 已采纳回答 4月2日
  • 创建了问题 3月27日

悬赏问题

  • ¥15 stm32f103串口无法正常发送接收数据
  • ¥15 如何仅使用递归法改变链表顺序
  • ¥30 频率与占空比均可调的方波发生器
  • ¥15 VB6.0中PICTUREBOX加载本地图片无法显示
  • ¥100 关于游戏app session获取的问题
  • ¥15 爬虫程序爬取TTGChina网站文章代码
  • ¥35 由于系统缓冲区空间不足或队列已满,不能执行套接字上的操作。
  • ¥15 如何用下图方法在AMESim中搭建离心泵模型
  • ¥15 C#连接服务器,请求时报Ssl/Tsl未能建立安全通道
  • ¥15 xcode15build的c++ dylib在10.15上不兼容