3

在我的程序中(使用 Python 2.7),我创建了一个包含一些重要数据和方法的对象。一些方法是 CPU 消耗的,所以在某些情况下,我在 CPU 密集型方法的持续时间内将对象移动到一个新的 QThread,然后让它们回到主线程。稍后,当调用 CPU 密集型方法时,我想再次将对象移动到另一个 QThread,但是这会失败说“当前线程不是对象的线程”。

这是一个重现问题的简单示例:

import sys
from PyQt4 import QtCore, QtGui
from time import sleep

class ClassA(QtGui.QDialog):
    def __init__(self):
        super(ClassA, self).__init__()
        mainLayout=QtGui.QVBoxLayout()
        self.lineEdit=QtGui.QLineEdit()
        mainLayout.addWidget(self.lineEdit)
        self.setLayout(mainLayout)
        self.show()
        self.obj=ClassC(self)        
        self.executeProgram()
    def executeProgram(self):
        self.lineEdit.setText("Starting new thread...")
        self.thread=QtCore.QThread()
        self.obj.moveToThread(self.thread)        
        self.thread.started.connect(self.obj.doWork)
        self.obj.doingWork.connect(self.updateGui)
        self.obj.finished.connect(self.killThread)
        self.thread.start()
    def updateGui(self,message):
        self.lineEdit.setText(message)
    def killThread(self):
        self.thread.quit()
        self.thread.wait()
        self.obj.finished.disconnect()
        self.executeProgram()

class ClassC(QtCore.QObject):
    finished=QtCore.pyqtSignal()
    doingWork=QtCore.pyqtSignal(str)
    def __init__(self,parent=None):
            super(ClassC, self).__init__()
    def doWork(self):
        for i in range(5):
            self.doingWork.emit("doing work: iteration "+str(i))
            sleep(1)
        self.finished.emit()

if __name__=="__main__":
    app=QtGui.QApplication(sys.argv)
    obj=ClassA()
    app.exec_()       

是否可以多次将对象移动到不同的 QThread?如果是这样,我将如何修复我的代码来做到这一点?

4

1 回答 1

4

注意moveToThread必须在对象当前所属的线程上调用,因此您可能需要将对象移回主线程,然后再将其移至另一个线程。

mainThread = QtCore.QThread.currentThread()在顶部某处添加线,并self.moveToThread(mainThread)在发出finished信号之前放置。

于 2013-05-11T23:15:31.847 回答