如何在python中使用多个线程调用相同的函数?

时间:2018-03-28 06:18:37

标签: python multithreading concurrency parallel-processing signal-processing

我正在使用python中的信号处理应用程序。我想在python中使用多个线程调用相同的函数,实现并发执行是否可以做到呢?如果是这样的话?

1 个答案:

答案 0 :(得分:1)

长话短说:不,因为Global Interpreter Lock

但是你可能想要考虑使用进程而不是线程,这似乎是你的应用程序的真正需要(从你的解释中可以理解),因为它似乎你不需要使用共享记忆空间。

一个(非常)简单的例子:

import multiprocessing

def worker(num):
    """ Worker procedure
    """
    print('Worker:', str(num))

# Mind the "if" instruction!
if __name__ == '__main__':
    jobs = [] # list of jobs
    jobs_num = 5 # number of workers
    for i in range(jobs_num):
        # Declare a new process and pass arguments to it
        p1 = multiprocessing.Process(target=worker, args=(i,))
        jobs.append(p1)
        # Declare a new process and pass arguments to it
        p2 = multiprocessing.Process(target=worker, args=(i+10,))
        jobs.append(p2)
        p1.start() # starting workers
        p2.start() # starting workers

此示例将为您提供以下输出:

$ python multiprocessing_example.py

Worker: 0
Worker: 10
Worker: 1
Worker: 11
Worker: 2
Worker: 12
Worker: 3
Worker: 13
Worker: 4
Worker: 14

为了充分利用多个进程,我建议你先了解一下the documentation of the module,GIL,线程和进程之间的区别,特别是它如何加速或限制你想要做的事情和如何。

例如,如果您的瓶颈是I / O,那么进行多处理将无法帮助您,但如果您的处理受到CPU的限制,则会有所帮助。