1
WKPlus 2016-03-04 13:39:50 +08:00
如果单写一个 While 1 循环,多开几个线程, cpu 使用率可能更高,据说是 GIL 限制的是纯 python 代码的并发,因此并不是一个 python 进程 cpu 使用率不能超过 100%。
具体哪些不是纯 python 代码,我也没查到,期待牛人解答。 SOF 上有一个类似的问题: http://stackoverflow.com/questions/11615449/python-interpreters-uses-up-to-130-of-my-cpu-how-is-that-possible |
2
ryd994 2016-03-04 13:44:55 +08:00
|
3
WKPlus 2016-03-04 13:50:19 +08:00
@ryd994 但是为啥一个 While 1: pass 也可以让 cpu 使用率超过 100%呢?难道解析器把这个代码优化了?
|
4
lebowsk1s 2016-03-04 14:06:07 +08:00 via Android
计算密集型的代码开多线程没用的,得上多进程, GIL 这锅目前无解,只能用各种方法绕过
|
5
nooper 2016-03-04 14:15:08 +08:00
python mpi 解决。
|
6
likuku 2016-03-04 14:24:32 +08:00
python 多线程被 GIL 局限,只能使用一个 core ,
一种解决办法是:任务对列化,按 CPU 核心数开多线程,每个多线程开 subprocess/独立子进程去执行任务。这样,可以用到所有 CPU 核心。 |
7
likuku 2016-03-04 14:24:59 +08:00
每个线程开一个 subprocess/独立子进程
|
9
virusdefender 2016-03-04 14:55:51 +08:00 1
IO 密集型开多线程, CPU 密集型开多进程
|
10
WKPlus 2016-03-04 15:57:39 +08:00
@ethego 因为超线程?如果仅仅是因为超线程,是不是应该不会超过 200%( 1 物理核超线程之后变成 2 虚拟核)。但我试过 while 1:pass 开 10 个线程的话, cpu 使用率能达到 950%左右
|