我正在我的应用程序中运行以下代码块。当使用python3.4运行它时,在屏幕上出现“ python意外退出”弹出窗口。 aOut文件中缺少的数据是一堆迭代的数据,并且是成块的。说列表中的0-1000个项目不存在,而其他项目有数据。其他项目无需干预即可自行正常运行。
使用python2.7时,失败的原因是列表中的〜3400-4400。
在日志记录中我看到,不对0-1000(即)process.start()调用进行调用detect()不会触发detect方法。
我正在MAC OS Sierra上执行此操作。这是怎么回事有没有更好的方法可以实现我的目的?
def detectInBatch (aList, aOut):
#iterate through the objects
processPool = []
pthreadIndex = 0
pIndex = 0
manager = Manager()
dict = manager.dict()
outline = ""
print("Threads: ", getMaxThreads()) # max threads is 20
for key in aList:
print("Key: %s, pIndex: %d"%(key.key, pIndex))
processPool.append(Process(target=detect, args=(key.key, dict)))
pthreadIndex = pthreadIndex + 1
pIndex = pIndex + 1
#print("Added for %d" %(pIndex))
if(pthreadIndex == getMaxThreads()):
print("ProcessPool size: %d" %len(processPool))
for process in processPool:
#print("Started")
process.start()
#end for
print("20 Processes started")
for process in processPool:
#print("Joined")
process.join()
#end for
print("20 Processes joined")
for key in dict.keys():
outline = outline + dict.get(key)
#end for
dict.clear()
pthreadIndex = 0
processPool = []
#endif
#endfor
if(pthreadIndex != 0):
for process in processPool:
# print("End Start")
process.start()
#end for
for process in processPool:
# print("End done")
process.join()
#end for
for key in dict.keys():
print ("Dict: " + dict.get(key))
outline = outline + dict.get(key)
#end for
#endif
aOut.write(outline)
#end method detectInBatch
答案 0 :(得分:0)
为避免“意外退出”,请尝试使用
忽略该异常try:
your_loop()
except:
pass
然后,进行一些日志记录以跟踪根本原因。