linux进程间 传文件句柄,在进程之间共享具有文件句柄属性的对象

我有一个关于进程间文件句柄共享资源的问题。

这是我的测试代码:from multiprocessing import Process,Lock,freeze_support,Queue

import tempfile

#from cStringIO import StringIO

class File():

def __init__(self):

self.temp = tempfile.TemporaryFile()

#print self.temp

def read(self):

print "reading!!!"

s = "huanghao is a good boy !!"

print >> self.temp,s

self.temp.seek(0,0)

f_content = self.temp.read()

print f_content

class MyProcess(Process):

def __init__(self,queue,*args,**kwargs):

Process.__init__(self,*args,**kwargs)

self.queue = queue

def run(self):

print "ready to get the file object"

self.queue.get().read()

print "file object got"

file.read()

if __name__ == "__main__":

freeze_support()

queue = Queue()

file = File()

queue.put(file)

print "file just put"

p = MyProcess(queue)

p.start()

然后我得到一个KeyError,如下所示:

^{pr2}$

我想当我把File()对象放入队列时,对象被序列化了,文件句柄不能被序列化,所以我得到了KeyError:

有人知道吗?如果我想用文件句柄属性共享对象,我应该怎么做?在

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值