QThread:线程仍在运行时被销毁

Ser*_*tin 16 python pyqt qthread

我在python中遇到QThreads的问题.我想改变标签的背景颜色.但我的应用程序在启动时崩溃."QThread:在线程仍在运行时被破坏"

   class MainWindow(QMainWindow):
      def __init__(self):
          QMainWindow.__init__(self)
          self.ui = Ui_MainWindow()
          self.ui.setupUi(self)

          statusTh = statusThread(self)
          self.connect(statusTh, SIGNAL('setStatus'), self.st, Qt.QueuedConnection)
          statusTh.start()

      def st(self):
          if self.status == 'ON':
              self.ui.label.setStyleSheet('background-color:green')
          else:
              self.ui.label.setStyleSheet('background-color:red')

  class statusThread(QThread):
      def __init__(self, mw):
          super(statusThread, self).__init__()

      def run(self):
          while True:
              time.sleep(1)
              self.emit(SIGNAL('setStatus'))

  if __name__ == "__main__":
      app = QApplication(sys.argv)
      main_window = MainWindow()
      main_window.show()
      sys.exit(app.exec_())
Run Code Online (Sandbox Code Playgroud)

rai*_*ner 30

你没有在创建线程后存储对线程的引用,这意味着在程序离开MainWindows 之后的某个时间它将被垃圾收集(即销毁)__init__.只要线程正在运行,您至少需要存储它,例如使用self.statusTh:

self.statusTh = statusThread(self)
self.connect(self.statusTh, SIGNAL('setStatus'), self.st, Qt.QueuedConnection)
self.statusTh.start()
Run Code Online (Sandbox Code Playgroud)

  • 正如我在回答中写的那样.通过将`statusThread(self)`的实例赋值给一个局部变量(即在它前面没有`self.),当局部变量超出范围时(在`__init__`时它会被垃圾收集) 'MainWindow`完成了).如果将引用存储在`MainWindow`类的成员变量中(即在其前面带有`self`),当`__init__`完成时它不会超出范围,导致线程对象不存在垃圾收集. (8认同)