我正在尝试理解线程在同一进程中运行时,它们如何相互作用和共享变量空间的微妙差别。以下代码展示了两个函数prod和consum,它们在不同的线程中运行。这两个函数都有相同的列表和锁参数:它们使用da_list来共享数据,并使用lockguy来同步/线程安全共享。
我的主要问题是:当我运行这段代码时,它打印出(1, 0, 0, 0, 0 ...)而不是我期望的(1,2,3,4,5,6...)。当我删除consum函数中的l = [0]行时,我得到了预期的行为。为什么l = [0]会弄乱它?当consum完成时,da_list应该是[0]。随后调用prod应该将da_list重置为[da_int]。谢谢你的帮助。
我的主要问题是:当我运行这段代码时,它打印出(1, 0, 0, 0, 0 ...)而不是我期望的(1,2,3,4,5,6...)。当我删除consum函数中的l = [0]行时,我得到了预期的行为。为什么l = [0]会弄乱它?当consum完成时,da_list应该是[0]。随后调用prod应该将da_list重置为[da_int]。谢谢你的帮助。
import threading
import time
def prod(l,lock):
da_int = 0
while True:
with lock:
time.sleep(0.1)
da_int += 1
l[0] = da_int
def consum(l,lock):
data = ''
while True:
with lock:
time.sleep(0.1)
print(l[0])
l = [0]
def main():
da_list = [0]
lockguy = threading.Lock()
thread1 = threading.Thread(target = prod, args=(da_list,lockguy))
thread2 = threading.Thread(target = consum, args=(da_list,lockguy))
thread1.daemon = True
thread2.daemon = True
thread1.start()
thread2.start()
try:
while True:
time.sleep(1)
except KeyboardInterrupt:
pass
finally:
print('done')
if __name__ == '__main__':
main()
consum
中的变量l
下方的列表,而是修改了其中的本地变量l
。 也就是说,l = [0]
不会 修改共享的l
列表。 它在consum
内部创建了一个新的列表,该列表与prod
不共享。 请注意,例如l[:] = []
将会 修改基础列表。 您还可以阅读以下内容:https://dev59.com/o3M_5IYBdhLWcg3wZSE6 - freakish