Python进程无法启动

时间:2018-07-03 15:12:37

标签: python python-3.x python-2.7 subprocess python-multiprocessing

我正在我的应用程序中运行以下代码块。当使用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

1 个答案:

答案 0 :(得分:0)

为避免“意外退出”,请尝试使用

忽略该异常
try:
    your_loop()
except:
    pass

然后,进行一些日志记录以跟踪根本原因。