- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试使用多处理 Pool 类将纯函数映射到一些不可变对象(immutable对象)上。然而,当我尝试运行它时,我在终端中看到大量错误(有时持续几分钟),并且通常,python“必须以不寻常的方式终止”。我在 Windows (XP) 上运行,使用 python 3.2.2。
import multiprocessing
def do_stuff(v):
return v.x + v.y
class Vector:
__slots__ = ['x', 'y']
def __setattr__(self, name, value):
raise AttributeError("Cannot assign values to object {0} of type {1}".format(self, type(self)))
def __init__(self, x, y = None):
"""Initialize an immutable x, y Vector"""
object.__setattr__(self, 'x', x)
object.__setattr__(self, 'y', y)
if __name__ == "__main__":
todo = [Vector(1, 2), Vector(3, 4), Vector(-1, 12), Vector(16, 32), Vector(16, 32)]
pool = multiprocessing.Pool(4)
results = list(pool.map(do_stuff, todo))
print(results)
预期输出:
[3, 7, 11, 48, 48]
错误数量非常多,但似乎可以归结为 pool.map 中尝试在 Vector 上设置属性的问题:
Process PoolWorker-1:
Traceback (most recent call last):
File "c:\Python32\lib\multiprocessing\process.py", line 267, in _bootstrap
Process PoolWorker-2:
Traceback (most recent call last):
File "c:\Python32\lib\multiprocessing\process.py", line 267, in _bootstrap
self.run()
File "c:\Python32\lib\multiprocessing\process.py", line 116, in run
self._target(*self._args, **self._kwargs)
File "c:\Python32\lib\multiprocessing\pool.py", line 102, in worker
task = get()
File "c:\Python32\lib\multiprocessing\queues.py", line 378, in get
return recv()
File "d:\Documents and Settings\Userdir\Scripts\temp\test.py", line 11, in __s
etattr__
raise AttributeError("Cannot assign values to object {0} of type {1}".format
(self, type(self)))
AttributeError: Cannot assign values to object <__main__.Vector object at 0x00C2
BBB0> of type <class '__main__.Vector'>
我可以注释掉以 __slots__
开头的行(奇怪?),使用常规 map
,或者我可以使 Vector 类可变(注释掉 __setattr__
),其中任何一个本身都会使其正常工作。
当我所做的只是从对象中读取数据时,为什么会尝试在我的对象上设置属性?
为什么删除__slots__
来自对象导致它正常工作?
编辑:
我正在使用__slots__
作为节省内存/空间的一种方式,因为我的程序中通常有大量向量。因此我无法从元组中导出向量: __slots__
do not work for classes derived from ''variable-length'' built-in types such as long, str and tuple
最佳答案
__slots__
导致 multiprocessing
出现 unpickling 问题,例如 python multiprocessing pickle protocol
由于您不需要它来实现不变性(您的 __setattr__
足以满足所有实际目的),我建议您将其删除。
如果您确实需要它来节省空间,请实现 __getstate__
和 __setstate__
这可以解决 unpickling 问题。
关于python - 从不可变对象(immutable对象)读取时使用 multiprocessing.pool 映射时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10077471/
我正在使用 boost.pool,但我不知道何时使用 boost::pool<>::malloc和 boost::pool<>::ordered_malloc ? 所以, boost::pool<>:
我目前正在尝试从 anaconda 中的 spy 控制台运行并行代码。我相信问题可能出在我的计算机不允许 anaconda 控制 CPU 核心上,但我不知道如何解决这个问题。 另一个有趣的点是,当我运
在了解 Python 的 multiprocessing 包(对于 Python 3.4 )时,我注意到 multiprocessing.Pool 是在类 BaseContext 中定义的 上下文.p
我有这样的程序: from multiprocessing import Pool import time def f(x): # I make a heavy code here to take t
我有一个模块 A,它通过获取数据并将其发送到模块 B、C、D 等进行分析,然后将它们的结果结合在一起来执行基本的 map/reduce。 但是模块 B、C、D 等似乎不能自己创建多处理池,否则我得到
所以我有一个脚本可以连接到大约 700 个设备并执行一系列命令,然后退出。我开始使用 Multiprocessing.Pool 和 Pool.map 来减少脚本的运行时间,并允许我同时登录多个设备。
在下面的链接中有对 Pool 类的 map 方法的解释。 它似乎阻塞直到结果准备好。这意味着不需要执行 pool.close(); pool.join() 在运行 pool.map 之后,但是它在 t
context 是 class multiprocessing.pool.Pool 构造函数中的可选参数。 Documentation只说: context can be used to specif
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: What's the difference between sending -release or -dra
不确定这是否是正确的论坛。 libvirt 页面链接在这里。如果这需要张贴在不同的地方请告诉我。 virsh pool-define-as 和 create-as 有什么区别?阅读 virsh 的手册
谁能告诉我Spring Cloud Feign Client是否提供或支持Http连接池,如果可以,那么如何配置诸如池大小的设置?我似乎在官方文档中找不到此内容。谢谢你。 最佳答案 通过调查,我将尝试
我在尝试运行 Flask 应用程序时遇到了一些困难。我收到以下导入错误: File "/db/mysql_utils.py", line 2, in import mysql.conne
我有一个 Node 项目,在其中使用 pg-pool 库。我已在我的依赖项中包含以下内容: "@types/pg-pool": "0.0.3", "pg": "^7.3.0", "pg-format"
在 python 2 中,multiprocessing.dummy.Pool 和 multiprocessing.pool.ThreadPool 之间有什么区别吗?源代码似乎暗示它们是相同的。 最佳
这个问题在这里已经有了答案: Concurrent.futures vs Multiprocessing in Python 3 (6 个答案) 关闭 5 年前。 请给我解释一下这两个类有什么区别?
multiprocessing 的文档states以下关于Pool.join() : Wait for the worker processes to exit. One must call clos
我找到了一些资源,但我不确定我是否理解。 我找到的一些资源是: http://help.sap.com/saphelp_nw70/helpdata/en/fc/eb2ff3358411d1829f00
我的 Javafx 应用程序抛出许多非法状态异常,我尚未能够在源中跟踪触发器。 任何人都可以指导我导致此问题的原因以及我应该在哪里查找原因。我很难在这里展示一些代码,因为我不知道是什么原因造成的。 任
参见下面的示例和执行结果: #!/usr/bin/env python3.4 from multiprocessing import Pool import time import os def in
我目前有一个连接到我的主数据库的开放池,它运行良好。但是现在,我想为另一个数据库打开一个新池。我完全按照设置第一个池的方式设置了新池,显然我编辑了数据库名称等。加载 setupHikari() 方法时
我是一名优秀的程序员,十分优秀!