是的,其他人之前已经问过这个问题,但不是在相同的背景下或我的满意。所以,这里是::
我正在使用python编写一个应用程序,该程序使用pygame(ergo opengl)来显示图形。图形是在程序本身中生成的(因此没有任何目录问题)。
应用程序还需要从用户平行访问输入。为了实现这一点,我使用带管道的多处理块,并使用pygame事件循环读取输入键。下面的代码循环运行。第一次循环迭代工作正常,但在第二次迭代时,我抛出了XIO错误。
parent, child = Pipe(duplex=True)
# this function draws the canvas
switches, retOrient = self.drawCanvas(cond, count, dispSize, moves)
# this function gets the user input in another thread - stage 1
p = Process(target=userInput, args=(self.button, child) )
p.start()
b_press = parent.recv()
parent.close()
def userInput(button, child):
button_pressed = button.blockAndWait()
child.send( "%s"%(button_pressed.keyname) )
child.close()
我对这个错误的发生方式感到有些困惑,XIO内部导致它的原因是什么。其他答案都没有解释这个错误的根本原因。考虑到它作为单个流程应用程序工作正常,多处理模块正在关闭一些IO通道(输入注册对象,显示对象或事件循环)或打开一些不必要的通道。如何解读导致此XIO错误的确切原因?
答案 0 :(得分:8)
不一定是真正的答案,但我不会使用multiprocessing
并行访问套接字,例如与X服务器的连接。这看起来不错。改为使用常规线程。
请注意multiprocessing
是基于(有时)分叉的黑客攻击,所以当父母和孩子都试图访问它时,分叉套接字究竟会发生什么......是随机混合垃圾。
编辑:原因是两个分叉套接字仍然是套接字的“同一端”,X服务器保持在“另一端”。当X服务器想要发送消息时,它会在套接字上写入100个字节。但是如果你运气不好,分叉进程1读取前50个字节,分叉进程2读取剩余的50个字节。每个进程都意外地只获得了消息的随机部分。他们每个人都会抱怨X服务器发送废话。