Qt计划意外完成

时间:2014-12-27 18:13:50

标签: c++ sql qt sqlite autocomplete

我正在尝试在Qt中创建自动完成行编辑,但我的程序因为我无法理解而崩溃,导致崩溃的代码是

model_Customer->setTable("Customer");
model_Customer->select();
model_Product->setTable("Product");
model_Product->select();
Account_completer->setModel(model_Customer);
Product_completer->setModel(model_Product);
Account_completer->setCaseSensitivity(Qt::CaseInsensitive);
Product_completer->setCaseSensitivity(Qt::CaseInsensitive);
AutoComplete();
ui->lineEdit_Invoice_Account->setCompleter(Account_completer);
ui->lineEdit_Invoice_Product->setCompleter(Product_completer);

我的.h文件位于

之下
QSqlDatabase db;
QSqlTableModel *model_Customer;
QSqlTableModel *model_Product;
QCompleter *Account_completer;
QCompleter *Product_completer;

谢谢

1 个答案:

答案 0 :(得分:1)

当您尝试使用未分配的指针时,您正在使用悬挂指针,其行为未定义,但大多数情况下,它是崩溃。在最坏的情况下,这是一个让你的程序表现得很奇怪的错误。

请记住始终初始化您的指针,即使它是0NULLnullptr。如果您能够使用C ++ 11或更高版本,那么最好是习惯于就地进行统一初始化。

此外,使用valgrind,gdb和其他内存跟踪器等工具可以更容易地发现这些问题。