我运行了这段代码
NUM = 0
def count():
global NUM
NUM += 1
time.sleep(1)
print(t.getName()+":"+"NUM is "+str(NUM))
for i in range(10):
t = threading.Thread(target=count)
t.start()输出是
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10
Thread-10:NUM is 10我知道为什么NUM总是10,但是为什么线程名总是相同的呢?每个线程都运行print(t.getName()+":"+"NUM is "+str(NUM));t不应该是获得cpu时间的线程吗?我认为名字不应该是一样的。
当我换了这个
NUM = 0
def count():
global NUM
NUM += 1
name = t.getName()
time.sleep(1)
print(name+":"+"NUM is "+str(NUM))
for i in range(10):
t = threading.Thread(target=count)
t.start()它如我所期望的那样工作:
Thread-1:NUM is 10
Thread-3:NUM is 10
Thread-2:NUM is 10
Thread-4:NUM is 10
Thread-5:NUM is 10
Thread-7:NUM is 10
Thread-10:NUM is 10
Thread-9:NUM is 10
Thread-6:NUM is 10
Thread-8:NUM is 10发布于 2017-06-20 00:18:01
这是因为您引用的是全局名称t。当休眠结束时,循环结束,t仍然绑定到创建的最后一个线程(第10个线程)。
在您的替代方案中,结果实际上没有定义。在这里,您在循环仍在运行时引用全局t,因此它很可能绑定到最近创建的线程--但不必绑定。
注意:如果您无法方便地访问当前正在运行的线程对象,则可以使用
threading.currentThread()为了得到它。然后
threading.currentThread().getName()将返回运行它的线程的名称。
发布于 2017-06-20 00:17:13
线程名和计数NUM都有相同的问题:当您到达第一个print语句时,所有10个线程都已经启动。线程只有一个全局变量t,计数只有一个全局NUM。因此,您所看到的只是最后一个值,即第10个线程的值。如果要打印单独的值,则需要为代码提供一种机制,以便在启动时报告它们,或者保留一个可以迭代的列表。
发布于 2017-06-20 00:32:07
我建议你试试这个:
NUM = 0
def count():
global NUM
NUM += 1
num = NUM
name = t.getName()
time.sleep(1)
print("t.getName: " + t.getName() + ", name: " + name + ":" + ", NUM: " + str(NUM) + ", num: " + str(num))
for i in range(10):
t = threading.Thread(target=count)
t.start()结果:
t.getName: Thread-10, name: Thread-10:, NUM: 10, num: 10
t.getName: Thread-10, name: Thread-6:, NUM: 10, num: 6
t.getName: Thread-10, name: Thread-3:, NUM: 10, num: 3
t.getName: Thread-10, name: Thread-5:, NUM: 10, num: 5
t.getName: Thread-10, name: Thread-4:, NUM: 10, num: 4
t.getName: Thread-10, name: Thread-9:, NUM: 10, num: 9
t.getName: Thread-10, name: Thread-7:, NUM: 10, num: 7
t.getName: Thread-10, name: Thread-2:, NUM: 10, num: 2
t.getName: Thread-10, name: Thread-1:, NUM: 10, num: 1
t.getName: Thread-10, name: Thread-8:, NUM: 10, num: 8t.getName()是一个函数调用,它是一个引用。当打印函数到达控制台时,t引用最新的线程。
https://stackoverflow.com/questions/44641733
复制相似问题