2

我正在使用 QThread 做一些周期性的后台工作,源代码看起来像这样

class Worker(QObject):
    """ Separate QObject that does the work with affinity of 
        'DoStuffOnceASecond'"""
    def __init__(self):
        super(QWorker, self).__init__()

    def doWork(self):
        #... do work, post signal to consumer


class DoStuffOnceASecond(QThread):
    def __init__(self):
        super(DoStuffOnceASecond, self).__init__()   

    def run(self):
        """ Setup "pullFiles" to be called once a second"""
        self.timer= QTimer()
        self.worker = Worker()
        self.timer.setSingleShot(False)
        self.timer.timeout.connect(self.worker.doWork)
        self.timer.start(1000)
        self.exec_()

我正在寻找终止此类线程的最佳方法。一种选择是将信号从主线程发布到该线程,在该线程中创建一个插槽。由于这些插槽作为事件循环的一部分执行,因此它们会被安全地拾取。但后来我会自我终止......而且我不确定这是否会很好地工作。

或者我想知道,因为线程应该意识到它正在运行一个事件循环,如果只是调用exit()这个线程是安全的?该文档 似乎表明这是可以的:

调用此函数后,线程离开事件循环并从对 QEventLoop::exec() 的调用返回。QEventLoop::exec() 函数返回returnCode。

认为“离开事件循环”意味着它将允许当前事件完成处理。还是 QThread 会立即终止?

这里的代码是 python(pyside 1.10,python 2.7),但这可以很容易地应用于任何使用 QThread 的 QT 代码。

4

1 回答 1

1

如果您不介意返回码为 0,则无需声明任何额外的插槽。然后您可以使用已定义 quit()的插槽,它只调用exit(0)您的线程。关于你对“自我终止”的恐惧——你并没有终止线程,只是退出了它的事件循环。您可以随时通过再次调用 exec() 来启动它。你对你的线程仍然很好,所以一切都应该“工作得很好”。QThread::terminate可以立即终止,但是当上述方法失败时,它意味着最后一个绝望的手段来杀死线程。

于 2012-08-14T21:03:20.627 回答