Я внедрил версию рабочего шаблона, описанную в Qt Threading docs.Как отправить None с сигналами через потоки?
Я использую Signals/Slots
для отправки данных между рабочей нитью и основным потоком.
При определении Signal
я установил тип сигнатуры аргумента object
, так как я считаю, что он должен позволить мне передать любой объект python через Signal
.
result_ready = QtCore.Signal(object)
Однако, когда я пытаюсь передать None
через Signal
он выходит из строя питона. Это происходит только при попытке передать Signal
по потокам. Если я прокомментирую линию self.worker.moveToThread(self.thread)
, она работает, и None
успешно проходит через Signal
.
Почему я не могу пройти None
в этом случае?
Я использую PySide 1.2.2
и Qt 4.8.5
.
import sys
from PySide import QtCore, QtGui
class Worker(QtCore.QObject):
result_ready = QtCore.Signal(object)
@QtCore.Slot()
def work(self):
print 'In Worker'
# This works
self.result_ready.emit('Value')
# This causes python to crash
self.result_ready.emit(None)
class Main(QtGui.QWidget):
def __init__(self):
super(Main, self).__init__()
self.ui_lay = QtGui.QVBoxLayout()
self.setLayout(self.ui_lay)
self.ui_btn = QtGui.QPushButton('Test', self)
self.ui_lay.addWidget(self.ui_btn)
self.ui_lay.addStretch()
self.setGeometry(400, 400, 400, 400)
self.worker = Worker()
self.thread = QtCore.QThread(self)
self.worker.moveToThread(self.thread)
self.thread.start()
self.ui_btn.clicked.connect(self.worker.work)
self.worker.result_ready.connect(self.handle_worker_result)
@QtCore.Slot(object)
def handle_worker_result(self, result=None):
print 'Handling output', result
def closeEvent(self, event):
self.thread.quit()
self.thread.wait()
super(Main, self).closeEvent(event)
if __name__ == '__main__':
app = QtGui.QApplication(sys.argv)
obj = Main()
obj.show()
app.exec_()
Да, но это не сработает, если вы используете тип объекта, который фактически пытается испустить OP (т. Е. 'Type (None)'). – ekhumoro
Согласитесь .. это было всего лишь обходным решением – Achayan