Qt中使用QThread来创建线程,QThread::wait()函数用于等待线程的结束,该函数会阻塞调用它的线程,直到线程结束。
要退出线程,可以察中迅在线程类中实现quit()函数,在该函数中设置一个标志位,表示线程要结束,然后在线程的run()函数中败此检测该标志位,如果标志位为true,则退出run()函数,线程就会结束培李。
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自身的特点,主线程关闭时,子线程就可毁厅以安全地退出了,而不会出现你现在这种情况了。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)