我有这样的程序
manager = Manager();
nodes = manager.dict();
p1 = Process(target = advertise, args=(nodes,));
p1.start();
p2 = Process(target = receive, args=(nodes,));
p2.start();
def advertise(nodes):
while(1):
nts = json.dumps(nodes.copy());
for k, v in nodes.items():
# Creates a UDP socket
mySocket = createSocket(getMyIP(), PORT);
mySocket.connect((getMyIP(), v[1]));
mySocket.send(("AD||" + nts).encode("ASCII"));
mySocket.close();
time.sleep(5);
def receive(nodes):
while(1):
mySocket = createSocket(getMyIP(), PORT);
mySocket.bind((getMyIP(), PORT));
try:
data = mySocket.recv(4096).decode("ASCII").split("||");
if(data[0] == "AD"):
temp = json.loads(data[1]);
#print("Received: " + str(temp));
for k, v in temp.items():
nodes[k] = [float(v[0]), int(v[1])];
except:
mySocket.close();
其中一个接收dict并更新值,另一个发送dict。 我不能json.dumps文件(nodes)因为它说DictProxy不是jsondumpable,所以我没有json.dumps文件(节点.复制())
这是第一次工作(套接字正确发送字典),但第二次程序只是说
File "Dvr.py", line 40, in advertise
nts = json.dumps(nodes.copy());
File "<string>", line 2, in copy
File "/usr/lib/python2.7/multiprocessing/managers.py", line 758, in _callmethod
conn.send((self._id, methodname, args, kwds))
IOError: [Errno 32] Broken pipe
1)为什么这只在while循环中第一次起作用?
2)如何让它每次都工作?
固定 我只是使用线程而不是进程,这样就更容易拥有一个全局简单字典,而不必跨多个进程的内存空间共享一个字典
相关问题 更多 >
编程相关推荐