Python中文
首页
教程
问答
标签
搜索
登录
注册
Python多处理中Pickle-cython类
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我有一个用cython实现的类,它包含c指针,我正试图与python的多处理模块一起使用。该类接受DLL文件以返回类的实例。在</p> <p>我的问题是,虽然实例保留了它们的数据类型,但它们似乎是空的,也就是说,我可以访问它们的所有类函数,但它们丢失了我在它们进入之前设置的所有实例值。包含特殊_类的代码非常大,因此无法包含它。在</p> <pre><code>import time import multiprocessing as mp from special_module import special_class def run_task(tasks,nr): obj = tasks[nr]['data'] print obj.get_name() if __name__ == "__main__": m1 = special_class("a.dll") m2 = special_class("b.dll") tasks = dict() tasks[1] = {'data': m1} tasks[2] = {'data': m2} process1 = mp.Process(target = run_task, name = 'process1', args = (tasks, 1)) process2 = mp.Process(target = run_task, name = 'process2', args = (tasks, 2)) process1.start() time.sleep(0.2) process2.start() process1.join() process2.join() </code></pre> <p>上面的脚本给出了输出</p> ^{pr2}$ <p>正确的输出应该是</p> <pre><code>name.a name.b </code></pre> <p>如果我在函数run_任务中创建实例,它会很好地工作,但是我正在寻找一种方法,通过在主进程中创建实例来使它工作。这可能吗?在</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>我相信多处理过程把所有的争论都泡汤了。所以您需要告诉Python如何pickle特殊的_类。您只需要实现方法特殊的_类。uu reduce_uu,这样就可以正确地对数据进行pickle。在</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
6 回答
尽管python中的表达式为false,但循环仍在运行
3 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
6 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
6 回答
尽管python字典包含了大量的条目,但它并没有增长
5 回答
尽管python说模块存在,为什么我会得到这个消息?
4 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
4 回答
尽管stdout和stderr重定向,但未捕获错误消息
9 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
2 回答
尽管tkinter上的变量已更改,但显示未更改
1 回答
尽管try/except使用Python进行单元测试时出现断言错误
4 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
2 回答
尽管url有效,Pandas仍读取url的\u csv错误
6 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
2 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
3 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
6 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
2 回答
尽管下载了i,但找不到型号“fr”
6 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
2 回答
尽管为所有行指定了权重,网格(0)仍不起作用
6 回答