- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
问题:由于 python 使用“GIL”,python 是否能够同时运行其单独的线程?
信息:
看完this我不确定python是否能够利用多核处理器。像python一样出色,想到它会缺乏如此强大的能力,感觉真的很奇怪。所以感觉不确定,我决定在这里问。如果我编写一个多线程的程序,它是否能够在多个内核上同时执行?
最佳答案
答案是“是的,但是……”
但是当您使用常规线程进行并发时,cPython 不能。
您可以使用 multiprocessing
之类的内容, celery
或 mpi4py
将并行工作拆分为另一个进程;
或者你可以使用类似 Jython或 IronPython使用没有 GIL 的替代解释器。
更温和的解决方案是使用不与 GIL 冲突的库来处理繁重的 CPU 任务,例如 numpy
可以在不保留 GIL 的情况下完成繁重的工作,因此其他 python 线程可以继续。您也可以使用 ctypes
这样的图书馆。
如果您不进行 CPU 密集型工作,则可以完全(某种程度地)忽略 GIL 问题,因为 python 在等待 IO 时不会获取 GIL。
关于python - python能够在多核上运行吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7542957/
我正在使用 Java 编写一个时钟程序,该程序能够“滴答作响”,但它存在问题。我认为它与 getter 和 setter 或 toString() 方法有关。 计数器类 package clock;
const Index = () => { // Ref Links const frefLinks = { 1: useRef(1), 2: useRef(2), 3: useRef(3
所以我读了here不能 pickle 装饰函数。确实: import multiprocessing as mp def deco(f): def wrapper(*args, **kwarg
我在go1.11.2 linux/amd64 版本。当包godog使用 go get github.com/DATA-DOG/godog/ 安装,godog 可执行文件在 $GOPATH/bin/中创
如何正确压缩字符串,以便 PHP 能够解压缩? 我试过这个: public static byte[] compress(String string) throws IOException {
我们这里的问题是表明 在测试中使用 Kleene 代数。 在 b 的值由 p 保留的情况下,我们有交换条件 bp = pb;两个程序之间的等价性简化为等式 在 b 的值不被 p 保留的情况下,我们有交
我有一个与我的网络相关的非常奇怪的问题,我在具有多个接口(interface)的 VirtualBox 上安装了 RDO Grizzly OpenStack。 虚拟盒子: eth0 - managem
我正在尝试使用 Passport.js授权谷歌OAuth2在 Node.js .我整个星期都在尝试让它工作,但不知道为什么它不工作,所以现在我求助于 stack 寻求一些潜在的帮助。我已经尝试了所有在
我是一名优秀的程序员,十分优秀!