在进行编程过程中,经常用到在程序当中调用其它的程序,这就需要用到进程调用,在QT中就用到了QProcess的进行进程调用,其有QT自身的特点,用起来非常方便,与C++本身的接口不一样,其流程特点如下:
特点1:需要waitForStarted,判断程序启动是成功,还是失败
特点2:需要waitForFinished,判断程序是否结束
这也是比较传统的用法,当然,你不愿意判断结束,就可以不判断了。
一般使用时容易犯的错误,就是直接省略了特点1的处理过程,进行了特点2,正常的话,是没问题,然则被调用的程序出问题的话,那就难查找原因了,如下:
//QProcess的用法
void MainWindow::on_pushButton_2_clicked()
{
qDebug()<<"enter function MainWindow::on_pushButton_2_clicked";
QProcess myProcess;
QStringList arguments;
arguments += "1";
arguments += "2";
myProcess.start("./test", arguments);
myProcess.closeReadChannel(QProcess::StandardOutput);
myProcess.closeReadChannel(QProcess::StandardError);
myProcess.closeWriteChannel();
while(!myProcess.waitForFinished(500))
{
qDebug()<<"wait";
sleep(2);
QCoreApplication::processEvents(QEventLoop::AllEvents, 2000);
}
qDebug()<<"exit function MainWindow::on_pushButton_2_clicked";
}
上面代码看着是没问题的,正常是可以执行的,我专门测试了一个异常的情况,就是上面的./test程序是不存在的,执行情况如下:
enter function MainWindow::on_pushButton_2_clicked
wait
wait
wait
wait
wait
wait
wait
wait
发现了,程序进入了死循环,你也不知道什么原因,是不是,有些蒙了
原因是,程序启动就失败了,这时waitForFinished()函数会一直返回false,官方也有相应的说明:
Returns true if the process finished; otherwise returns false (if the operation timed out, if an error occurred, or if this QProcess is already finished)
说的很明白,如果进程已经结束了,会一直返回false,所以上面就进入了死循环。
那怎么解决呢?
下面就说说QProcess的标准流程了,如下:
//QProcess的用法
void MainWindow::on_pushButton_2_clicked()
{
qDebug()<<"enter function MainWindow::on_pushButton_2_clicked";
QProcess myProcess;
QStringList arguments;
arguments += "1";
arguments += "2";
myProcess.start("./test", arguments);
myProcess.closeReadChannel(QProcess::StandardOutput);
myProcess.closeReadChannel(QProcess::StandardError);
myProcess.closeWriteChannel();
if(myProcess.waitForStarted())
{
qDebug()<<"启动成功";
}
else
{
qDebug()<<"启动失败 error:"<
这样再执行,输出如下:
enter function MainWindow::on_pushButton_2_clicked
启动失败 error: "Process failed to start: 系统找不到指定的文件。"
这样的话,就知道错误了,也不会进入死循环了,这也说明,如果想得到程序返回的结果,waitForStarted()与waitForFinished()两个函数都不可少。