Python创建的线程数比预期的多2倍

时间:2012-08-28 12:05:59

标签: python multithreading

我是Python的新手,所以如果这很明显,我很抱歉。

我正在尝试构建多线程应用程序,但是当我想创建一个线程时,我得到两个而不是一个。

MyThread.py

from threading import Thread
import time

class MyThreadClass(Thread):

    def __init__(self):
        Thread.__init__(self)

    def run(self):
        print "starting " + self.getName() + "\n"
        from main import var1
        while True:
            print self.getName() + " is running\n"
            print "value: " + var1 + "\n"
            time.sleep(1)

main.py

from MyThread import MyThreadClass
var1 = "Test"
MyThreadClass().start()

我得到的输出

 Thread-1 is running
 Thread-2 is running
 Thread-1 is running
 Thread-2 is running
 Thread-1 is running
 Thread-2 is running
 .....

为什么会这样?我注意到如果我用MyThreadClass().start()替换MyThreadClass().run()我得到2个线程,但只有一个线程继续运行

 Thread-1 is running
 Thread-2 is running
 Thread-2 is running
 Thread-2 is running
 Thread-2 is running
 .....

知道代码有什么问题吗?

2 个答案:

答案 0 :(得分:9)

main.py中导入MyThread.py时,

  

MyThreadClass()。启动()

再次执行(因为模块被加载),因此启动了第二个线程。


您可以使用

替换该行,在main.py中创建一个保护条款
if __name__ == "__main__":
    MyThreadClass().run()

或更好,只需将var1传递给MyThreadClass作为参数,以避免循环依赖。

<强> MyThread.py

from threading import Thread
import time

class MyThreadClass(Thread):

    def __init__(self, var1):
        Thread.__init__(self)
        self.var1 = var1

    def run(self):
        print "starting " + self.getName() + "\n"
        while True:
            print self.getName() + " is running\n"
            print "value: " + self.var1 + "\n"
            time.sleep(1)

<强> main.py

from MyThread import MyThreadClass

if __name__ == "__main__":
    MyThreadClass("Test").run()

答案 1 :(得分:4)

您启动线程两次,一次是在运行main.py时(因为它是__main__模块),再次在MyThreadClass的{​​{1}} {{}}中导入时1}}方法。

run()语句将运行模块中的所有代码,而不仅仅是您要求的内容; import表单可以方便地将特定项目放入当前名称空间。

它在两个线程停止的原因是因为即使你在第二个线程中再次导入from,Python也不会重新执行模块的代码,因为它已经被加载了。如果不是那样的话,你就会有两个以上的主题; - )

使用the other answer中提到的main结构不仅对这种情况非常有用,而且适用于所有类型的模块,因为它允许您同时执行它们(许多模块将此用于测试代码)并导入它们,同时避免副作用。