Python2.7中的多处理/多线程3个嵌套循环

2024-10-01 07:35:39 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下代码片段:

for x in xrange(100,14000):
    for y in xrange(0,3000):
        for z in xrange(0,700):
            operationg_tag = "%s-%s-%s" % (x,y,z)
            operation_code = ....

            and more bunch of code is running here on the tag generated above

我在一个快速良好的硬件中运行这段代码,但是这些循环的性质很慢,因为没有在多处理/多线程中运行

在每个标记上执行所需的代码大约需要0.4秒。你知道吗

如何在这些嵌套循环中实现多处理/多线程以使其运行更快?我应该瞄准哪一个循环?你知道吗


Tags: andof代码inforhereismore
1条回答
网友
1楼 · 发布于 2024-10-01 07:35:39

在3个过程中打破第一个循环

    def func(start, final):
         for x in xrange(start, final):
              for y in xrange(0,3000):
                   for z in xrange(0,700):
        operationg_tag = "%s-%s-%s" % (x,y,z)
        operation_code = ....
    def main():
        total = 14000
        div_total = int(14000 / 3)
        rest_div_total = 14000%3
        t1 = multiprocessing.Process(target = func,name = "", args=(100, div_total)
        t2 = multiprocessing.Process(target = func,name = "", args=(div_total, div_total*2)
        t3 = multiprocessing.Process(target = func,name = "", args=(div_total*2, div_total*3 + rest_div_total + 1)
        list_threads = [t1,t2,t3]
        for i in list_threads:
           i.start()
        for i in list_threads:
           i.join()

    if __name__ == "__main__":
        main()

如果你愿意,你可以创建更多的进程,但是3这是个好主意。你知道吗

相关问题 更多 >