
1 WKPlus 2016 年 3 月 4 日 如果单写一个 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 年 3 月 4 日 @WKPlus GIL 是解释器的锁( I for interpreter ) 如果你写了个 C 模块,那么在 C 代码部分的计算量是可以不锁 GIL 的所以计算密集的核心部分可以试试写成 C 模块 |
4 lebowsk1s 2016 年 3 月 4 日 via Android 计算密集型的代码开多线程没用的,得上多进程, GIL 这锅目前无解,只能用各种方法绕过 |
5 nooper 2016 年 3 月 4 日 python mpi 解决。 |
6 likuku 2016 年 3 月 4 日 python 多线程被 GIL 局限,只能使用一个 core , 一种解决办法是:任务对列化,按 CPU 核心数开多线程,每个多线程开 subprocess/独立子进程去执行任务。这样,可以用到所有 CPU 核心。 |
7 likuku 2016 年 3 月 4 日 每个线程开一个 subprocess/独立子进程 |
9 virusdefender 2016 年 3 月 4 日 IO 密集型开多线程, CPU 密集型开多进程 |