python 2.7 类中使用多进程(multiprocessing)执行类函数时的问题

python 2.7 类中使用多进程(multiprocessing)执行类函数时报错 

PicklingError: Can't pickle <type 'instancemethod'>: attribute lookup __builtin__.instancemethod failed

首先这是python2.7的一个bug,所以最简单的办法就是升级到python3 

相关大神的文章的链接如下:

https://stackoverflow.com/questions/1816958/cant-pickle-type-instancemethod-when-using-multiprocessing-pool-map

http://bbs.chinaunix.net/thread-4111379-1-1.html

如果不升级python的话,就来改代码吧,我得改法如下大笑

import time
from multiprocessing import Pool
Class testClass():
	def upMethod(self):
		print '我是UP'
		time.sleep(1)
	def downMethod(self):
		print '我是DOWN'
		time.sleep(1)
  def multiProcess(self):
     p = Pool(2)
     aObj=p.apply_async(self, args=('up',))#这里是重点
     aObj=p.apply_async(self, args=('down',))#这里是重点
     p.close()
     p.join()
	def __call__(self,sign):#这里是重点
		if sign=='up':
	       		return self.upMethod()
		elif sign=='down':
	       		return self.downMethod()
if __name__=='__main__':
	testObj=testClass()
	testObj.multiProcess()
关于__call__的说明 http://www.cnblogs.com/superxuezhazha/p/5793536.html

关于为什么这样改,大家看文章吧,我就不多BB了,有问题可以问我,大家一起探讨再见

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值