一杯清酒邀明月
天下本无事,庸人扰之而烦耳。

摘要

Qt帮助文档中是这样介绍的:

bool QThread::isRunning () const
Returns true if the thread is running; otherwise returns false.

See also isFinished().

解释的一本正经,使用却不然。

问题:

使用QThread::isRunning标志量判断线程是否关闭时,判断出错,线程明明关闭,isRunning仍然显示true

解决方式:

使用isRunning 和 isFinished双标志量判断

程序说明:

界面程序(Display_PlayBack)负责显示数据,数据库读取线程(Thread_PlayBack)负责一直读取数据库。

界面程序创建的数据库线程,也负责回收其空间。

程序中的代码:

Thread_PlayBack.cpp

 1 void Thread_PlayBack::run()//一直读取数据库数据入缓存
 2 {
 3     int rowNum,columnNum,fieldNo_longitude,fieldNo_latitude;
 4     double x,y,scale;
 5     SqlData data;
 6     QString str = QString::fromUtf8("SELECT 经度,纬度 FROM HT_12 WHERE (航向!=0 or 航速!=0"\
 7                                     " or 航程!=0 or 距离!=0) and ( 总电压!=0 or 总电流!=0 )"\
 8                                     "and 系统工作时间>'2000-01-10 03:08:25' and 航次=%1;").arg(voyage_num);
 9     qDebug()<<"sql_str="<<str;
10  
11     QSqlQuery query(db);
12     if( !query.exec( str ))
13     {
14         qCritical()<<"exec failed!";
15     }
16     while (query.next()) {
17         //qDebug()<<"开始读取";
18         rowNum = query.at();//结果集的编号也就是行号
19         columnNum = query.record().count();//结果集中列的个数
20         fieldNo_longitude = query.record().indexOf("经度");
21         fieldNo_latitude = query.record().indexOf("纬度");
22         //qDebug()<<"行:"<<rowNum<<" 列:"<<columnNum<<endl;
23  
24         x = query.value( fieldNo_longitude ).toDouble();
25         y = query.value( fieldNo_latitude ).toDouble();
26         scale=qPow(10,-7);
27         if(rowNum==0){//记录
28         }
29  
30         data.longtitude = QString::number(x*scale,10,5);//QString中的number函数转换
31         data.latitude   = QString::number(y*scale,10,5);//参数:double值,进制格式,几位小数
32         Display_PlayBack::dataPlayBack.mutex.lock();
33         Display_PlayBack::dataPlayBack.sqlData.append(data);
34         Display_PlayBack::dataPlayBack.mutex.unlock();
35  
36     }//读取完数据就跳出循环,然后依次结束自己
37     QMutexLocker locker(&mutex);//run结束时,标志量isStop设为真,代表关闭了数据库连接
38     isStop = true;
39     SqlConnectionPool::closeConnection(db);
40  
41     //关闭数据库读取线程
42     qDebug()<<"读取完毕,关闭自身!";
43     this->closeThread();
44     return;
45 }
46  
47 void Thread_PlayBack::closeThread()
48 {
49     QMutexLocker locker(&mutex);
50     if(false == isStop)//如果标志量isStop为假,说明提前结束线程,需要手动关闭连接
51     {
52         SqlConnectionPool::closeConnection(db);
53     }
54     this->quit();
55     this->wait();//标准线程结束释放
56 }

display_playback.cpp

 1 void Display_PlayBack::on_Button_End_clicked()
 2 {
 3     qDebug()<<"终止回放";
 4     ui->Button_Start->setText(QString::fromUtf8("开始"));
 5     ui->Button_Start->setChecked(false);
 6     //-----------航次选择combox设置为可选取----------//
 7     ui->ComboBox_Voyage->setEnabled(true);
 8     //静态变量置空
 9     Display_PlayBack::dataPlayBack.mutex.lock();
10     Display_PlayBack::dataPlayBack.sqlData.erase(Display_PlayBack::dataPlayBack.sqlData.begin()\
11                                                 ,Display_PlayBack::dataPlayBack.sqlData.end());
12     qDebug()<<"静态缓存size="<<Display_PlayBack::dataPlayBack.sqlData.size();
13     //vector::erase()用于清空容器中的内容以及释放内存,并返回指向删除元素的下一个元素的迭代器。
14     Display_PlayBack::dataPlayBack.mutex.unlock();
15     //判断数据库读取线程是否关闭
16     if( (!thread_playBack->isRunning()) || (thread_playBack->isFinished()) )
17     {
18         qDebug()<<"线程还没结束";
19         thread_playBack->closeThread();
20     }
21 }

解决!!!主要还是判断的isFinished标志量 

posted on 2022-05-07 22:59  一杯清酒邀明月  阅读(1558)  评论(0编辑  收藏  举报