线程中的传递引用可变变量

时间:2014-12-10 14:20:31

标签: python multithreading multiprocessing pass-by-reference

我有一个关于Python中多线程的基本问题:我有一个列表,我需要在一个线程中修改它。我知道列表是一种可变类型:How do I pass a variable by reference?

但是,当我使用线程时,列表的行为不像可变类型:

from multiprocessing import Process, Lock

def f(l, i, n):
    l.acquire()
    i.append(n)
    l.release()
    print "in:", i

if __name__ == '__main__':
    lock = Lock()

    i = []
    for num in range(10):
        p = Process(target=f, args=(lock, i, num))
        p.start()
        p.join()

    print "out:", i

输出

in: [0]
in: [1]
in: [2]
in: [3]
in: [4]
in: [5]
in: [6]
in: [7]
in: [8]
in: [9]
out: []

有人可以帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:4)

代码不使用线程,而是使用不共享内存的进程。

使用线程:

from threading import Thread, Lock  # <----

def f(l, i, n):
    l.acquire()
    i.append(n)
    l.release()
    print "in:", i

if __name__ == '__main__':
    lock = Lock()

    i = []
    for num in range(10):
        p = Thread(target=f, args=(lock, i, num))  # <----
        p.start()
        p.join()

    print "out:", i