Qt
程序异常终止的原因:\x0d\x0a\x0d\x0a一、在使用
指针之前,要进行指针是否为null的判断,如果为NULL却直接使用该指针,就会异常终止。如在QTableView:\x0d\x0aQStandardItemModel*model=newQStandardItemModel\x0d\x0amodel->item(0,1)->text()\x0d\x0a单元格没编辑过,直接用model->item(0,1)->text()的话,程序会异常终止。\x0d\x0a\x0d\x0a二、析构函数中加入释放内存的delete代码后,关闭Qt应用程序,会出现程序异常终止或猜,去掉析构函数里delete的代码就没有问题了。我是在工程中额外添加一个继承自QTableView的Qt设计师界面类,并在ui_widget.h中,即widget.ui界面的源码中,将QTableView改为我这个添加的类的类名。在新建的类的cpp文件中,注释掉\x0d\x0a,ui(newUi::CTblView)\x0d\x0aui->setupUi(this)\x0d\x0a\x0d\x0a两行,但没有注释掉\x0d\x0adeleteui\x0d\x0a\x0d\x0a原因和第一点一样,ui定义了没有使用,就直接delete,谈橡故而导衫侍型致程序异常终止。也注释掉这行就正常了。\x0d\x0a\x0d\x0a三、指针对象没有实例化就进行引用\x0d\x0a如:\x0d\x0aDialog*dd=newDialogd->show()如果忘了第二行的实例化,也会导致Qt程序异常终止。这种情况很正常,Python自肢余茄身的线程并不安全且不与PyQt兼容,你既然用PyQt了,为什么不尝试用Qt自身的线程类QThread呢历察?那么基于Qt自身的特点,主线程关闭时,子线程就可毁厅以安全地退出了,而不会出现你现在这种情况了。进洞耐程关橡谨闭纳如春外部程序:
QString KillStr = "taskkill /f /im main.exe"
QProcess *Process = new QProcess(this)
Process->start(KillStr)
评论列表(0条)