【发布时间】:2013-07-28 16:58:24
【问题描述】:
如果我运行这段代码:
#!/usr/local/bin/ python3
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *
class Window(QMainWindow):
def __init__(self):
super().__init__()
self.button1 = QPushButton("1")
self.button2 = QPushButton("2")
self.setCentralWidget(self.button1)
self.button1.clicked.connect(lambda: self.setCentralWidget(self.button2))
self.button2.clicked.connect(lambda: self.setCentralWidget(self.button1))
self.show()
if __name__ == '__main__':
import sys
app = QApplication(sys.argv)
window = Window()
sys.exit(app.exec_())
...我得到这个输出:
Traceback (most recent call last):
File "test.py", line 16, in <lambda>
self.button2.clicked.connect(lambda: self.setCentralWidget(self.button1))
RuntimeError: wrapped C/C++ object of type QPushButton has been deleted
我不明白为什么要删除该对象。 Window 应该保持对它的引用。 我已经彻底调查了这些帖子: Understanding the “underlying C/C++ object has been deleted” error Can a PyQt4 QObject be queried to determine if the underlying C++ instance has been destroyed?
为什么按钮会被删除?
【问题讨论】:
-
我在 QWidget 的子类中遇到了类似的问题,结果问题是我忘记在我的
__init__开头调用 QWidget 的__init__。诡计多端。 -
在我们的例子中,调用
a.call_some_parent_method(),其中a = QObjectA(parent=QObjectB()),引发了RuntimeError: wrapped C/C++ object of type QObjectA has been deleted。然而,实际原因竟然是QObjectB类型的包装对象已被删除(不是错误消息中提到的QObjectA)。解决方案是保留对QObjectB的引用:b = QObjectB(); a = QObjectA(parent=b)(使用 Python 2.7,PyQt5)
标签: garbage-collection pyqt pyqt4 qobject qmainwindow