转载请注明出处:
参考网址:
修改别人程序的时候,使用torch多线程load数据,遇到了这个问题:
FATAL THREAD PANIC:(write) XXX/torch/install/share/lua/5.1/torch/File.lua:141:Unwritable objectat .callback.self.XXX.DataLoader.threads.__gc__
中juesato给出了解释(我这边可以解决,不清楚是否都是这一个问题)
threads:addjob里面,不能使用self.XXX。
上面错误的意思是:DataLoader的对象不能被并行化。修改的程序的目的是直接在addjob里面调用self,但是threads库并不知道self代表什么变量,因而会提示上面的错误。
具体的解决方法参见juesato的回复。我这里直接把调用self的都在外面声明了(或者作为threads:addjob的第一个function的参数传入该function也行)。
addjob的使用参见: