首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么这10个线程总是输出相同的线程名?

为什么这10个线程总是输出相同的线程名?
EN

Stack Overflow用户
提问于 2017-06-20 00:08:17
回答 3查看 527关注 0票数 3

我运行了这段代码

代码语言:javascript
复制
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()

输出是

代码语言:javascript
复制
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时间的线程吗?我认为名字不应该是一样的。

当我换了这个

代码语言:javascript
复制
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()

它如我所期望的那样工作:

代码语言:javascript
复制
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
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-06-20 00:18:01

这是因为您引用的是全局名称t。当休眠结束时,循环结束,t仍然绑定到创建的最后一个线程(第10个线程)。

在您的替代方案中,结果实际上没有定义。在这里,您在循环仍在运行时引用全局t,因此它很可能绑定到最近创建的线程--但不必绑定。

注意:如果您无法方便地访问当前正在运行的线程对象,则可以使用

代码语言:javascript
复制
threading.currentThread()

为了得到它。然后

代码语言:javascript
复制
threading.currentThread().getName()

将返回运行它的线程的名称。

票数 7
EN

Stack Overflow用户

发布于 2017-06-20 00:17:13

线程名和计数NUM都有相同的问题:当您到达第一个print语句时,所有10个线程都已经启动。线程只有一个全局变量t,计数只有一个全局NUM。因此,您所看到的只是最后一个值,即第10个线程的值。如果要打印单独的值,则需要为代码提供一种机制,以便在启动时报告它们,或者保留一个可以迭代的列表。

票数 2
EN

Stack Overflow用户

发布于 2017-06-20 00:32:07

我建议你试试这个:

代码语言:javascript
复制
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()

结果:

代码语言:javascript
复制
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: 8

t.getName()是一个函数调用,它是一个引用。当打印函数到达控制台时,t引用最新的线程。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44641733

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档