6

我正在编写一个中型应用程序,用于存储基于 sqlite 数据库的数据。我创建了一个对话框来将数据添加到数据库中。在保存数据之前,它会检查一些条件以确保输入的数据是有效的。这是一个简单的散文。并且容易发现故障。我很高兴他们没有错误地使应用程序崩溃。应用程序也编译没有错误。有时它运行良好,但大多数探测它会崩溃并关闭。

  1. 我的第一个问题是为什么会发生这种事情。(有时它运行良好,有时它在相同的条件下崩溃)。

  2. 在这种情况下如何查找故障。我所做的只是,我使用更改逻辑和更改代码,认为它会更改二进制文件并纠正错误。

    前任:-

    if(query.exec()){
         //codes here.
     }
    

    我将把这段代码替换为

    bool ok=query.exec();
      if(ok){
           //code here....
     }
    

请在这种情况下帮助我,我将不胜感激任何建议。我将添加newMember.hand newMember.cpp which 使应用程序崩溃。(这是我的new member对话类)。如果需要更多数据,请告诉我我也会添加它们。

在错误报告中,在错误签名中提到了ModName:qtgui4.dll , Offset: 000c14e6

新成员.h

       #ifndef NEWMEMBER_H
       #define NEWMEMBER_H

       #include "ui_newmember.h"


       class newMember : public QDialog, private Ui::newMember
       {
           Q_OBJECT

       private:
           QString path_1;
           QPixmap pic;

       public:
           newMember(QString str, QWidget *parent );


       public slots:
           void browse();
           void save_2();

      };

      #endif // NEWMEMBER_H

新成员.cpp

        #include "newmember.h"
        #include<QtGui>
        #include<QtSql/QSqlDatabase>
        #include <QSqlQuery>
        #include <QSqlError>

        newMember::newMember(QString str, QWidget *parent)
        {
              setupUi(this);
           lineEdit_7->setText(str);
           radioButton->setChecked(true); ;

           connect(pushButton,SIGNAL(clicked()),this,SLOT(browse()));
           connect(pushButton_2,SIGNAL(clicked()),this,SLOT(save_2()));
        }


        void newMember::browse(){
             path_1=QFileDialog::getOpenFileName(this,"choose an image for the new house", QString::null,"Image Files (*.jpg *.bmp)");
             pic.load(path_1);
             pic=pic.scaled(284,213,Qt::KeepAspectRatio, Qt::SmoothTransformation);
             label_14->setPixmap(pic);
        }

        QString input1(QString str){
             if(str=="")
                 return "-NA-";
              else
                return str;
        }


       void newMember::save_2(){
             QByteArray array;
             QBuffer buf(&array);
             buf.open( QIODevice::WriteOnly);
             pic.save(&buf,"jpg");

             QString mof;
             if(radioButton->isChecked())mof="male";
             if(radioButton_2->isChecked())mof="female";

             QString isgm="false";
             if(checkBox->isChecked())isgm="true";


            QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");
            db.setDatabaseName("data");
            db.open();

            QSqlQuery query;
            query.exec("create table members(aname text, homeno text, namein text, fname text, onames text, nic text, sex text, bday text,gm text,occupation text,contactno text,qulification text,note text, img BLOB) ");

             if(lineEdit_8->text()==""){
             QMessageBox::about(this,"error","you should enter a name to identify this member \n within the specific house");
             return;
             }

             query.prepare("select aname from members where homeno=? and aname=?   ");
             query.bindValue(0,lineEdit_7->text());
             query.bindValue(1,lineEdit_8->text());
             query.exec();
             if(query.next()){
             QMessageBox::about(this, "error", "the name you entered to identify this member \n  is already available, please enter another one") ;
             return;
            }

              if(isgm=="true"){
                  query.prepare("select aname from members where homeno=? and gm=?");
                  query.bindValue(0,lineEdit_7->text());
                  query.bindValue(1,"true");
                  query.exec();
                      if(query.next()){
                          QMessageBox::about(this, "error", "there is a gruha mulikaya set already");
                         return;
                        }
                }


                 query.prepare("insert into members(aname, homeno , namein , fname , onames , nic , sex , bday ,gm ,occupation ,contactno ,qulification ,note ,img) VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?)     ");
                 query.bindValue(0,lineEdit_8->text());
                 query.bindValue(1,input1(lineEdit_7->text()));
                 query.bindValue(2,input1(lineEdit->text()));
                 query.bindValue(3,input1(lineEdit_2->text()));
                 query.bindValue(4,input1(lineEdit_3->text()));
                 query.bindValue(5,input1(lineEdit_4->text()));
                 query.bindValue(6,mof);
                 query.bindValue(7,dateEdit->date().toString("yyyy-MM-dd") );
                 query.bindValue(8,isgm);
                 query.bindValue(9,input1(lineEdit_5->text()));
                 query.bindValue(10,input1(lineEdit_6->text()));
                 query.bindValue(11,input1(textEdit->toPlainText()));
                 query.bindValue(12,input1(textEdit_2->toPlainText()));
                 query.bindValue(13,array);


                bool ok=query.exec();
                if(!ok){
                   QSqlError error;
                   error=query.lastError();
                   QMessageBox::about(this,"error",error.text()   );
                 }
                else{
                    QMessageBox::about(this,"message","data added successfully");
                    newMember::close();
                 }

              }
4

1 回答 1

4
  1. 尝试在调试器下运行您的应用程序。它将显示您的应用程序在代码中崩溃的位置。在您的情况下,它可能是段错误。
  2. 为什么不检查返回值?
于 2012-12-26T13:52:18.080 回答