QT开发之QProcess进程运行外部程序

Qt提供了一个QProcess类用于启动外部程序并与之通信,启动一个新的进程的操作非常简单,只需要将待启动的程序名称和启动参数传递给start()函数即可.

 当调用start()函数后,myProcess进程立即进入启动状态,但程序ls尚未被调用,不能读写标准输入输出设备.当进程完成启动后就进入"运行状态"并向外发出started()信号.在输入输出方面,QProcess将一个进程看做一个流类型的I/O设备,可以像使用QTcpSocket读写流类型的网络连接一样来读写一个进程.可以通过QIODevice::write()函数向所启动进程的标准输入写数据,也可以通过QIODevice::read()、QIODevice::readLine()和QIODevice::getChar()函数从这个进程的标准输出读数据.此外由于QProcess是从QIODevice类继承而来的,因四级,它也可以作QXmlReader的数据在源,或者为QFtp产生上传数据.最后,当进程退出时QProcess进入起始状态----"非运行状态",并发出finished()


信号在参数中返回了进程退出的退出码和退出状态,可以调用exitCode()函数和exitStatus()函数分别获取最后退出进程的这两个值.其中,Qt定义的进程"退出
状态"只有正常退出和进程崩溃两种,分别对应值QProcess::NormalExit(值0)和QProcess::CrashExit(值1).当进程在运
行中产生错误时,QProcess将发出error()信号,可以通过,调用error()函数返回最后一次产生错误的类型,并通过,state()
找出此时进程所处的状态.Qt定义了如下的进程错误代码:
----------------------------------------------------------------
错误常量                                值       描述
QProcess::FailedToStart        0        进程启动失败
QProcess::Crashed                1        进程成功启动后崩溃
QProcess::Timedout               2        最后一次调用waitFor...()函数超时.此时QProcess状态不变,并可以再次             调waitFor()类型的函数
QProcess::WriteError              3        向进程写入时出错.如进程尚未启动,或者输入通道被关闭时
QProcess::ReadError              4        从进程中读取数据时出错.如进程尚未启动时
QProcess::UnknownError       5        未知错误.这也是error()函数返回的默认值。

waitForStarted()阻塞直到进程已经启动;
waitForReadyRead()阻塞直到当前读通道上有可读的数据
waitForBytesWritten()阻塞直到一个有效负载数据已经被写入到进程
waitForFinished()阻塞直到进程已经结束

下面参考代码:

myProcess.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include 
#include 

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT
    
public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();
    
private slots:
    void on_pushButton_clicked();

private:
    Ui::MainWindow *ui;
    QProcess myProcess;
    QByteArray procOutput;

private slots:
    void showResult();
    void showState(QProcess::ProcessState);
    void showError();
    void showFinished(int,QProcess::ExitStatus);
};

#endif // MAINWINDOW_H

myProcess.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include 

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    connect(&myProcess, SIGNAL(readyRead()), this, SLOT(showResult()));
    connect(&myProcess, SIGNAL(stateChanged(QProcess::ProcessState)),
        this, SLOT(showState(QProcess::ProcessState)));
    connect(&myProcess, SIGNAL(error(QProcess::ProcessError)), this, SLOT(showError()));
    connect(&myProcess, SIGNAL(finished(int,QProcess::ExitStatus)),
        this, SLOT(showFinished(int, QProcess::ExitStatus)));

}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_pushButton_clicked()
{
#if 1
    QString cmd = ui->lineEdit->text();
    myProcess.start(cmd);
#else
    QString program="ls";
    QStringList arguments;
    arguments << "/home/linux/python";

    myProcess.start(program,arguments);
    //myProcess.startDetached() /* 启动外部程序不随主程序的退出而退出 */
#endif
    // 等待进程启动
    if (!myProcess.waitForStarted())
    {
        qDebug() << "启动失败\n";
        return;
    }
    myProcess.closeWriteChannel();


}

void MainWindow::showResult()
{
    //qDebug() << "shiwResult:" << endl << QString(myProcess.readAll());
    procOutput = myProcess.readAll();
    ui->textBrowser->setText(procOutput);
}

void MainWindow::showState(QProcess::ProcessState state)
{
    qDebug() << "showState:";

    if(state==QProcess::NotRunning){
        qDebug() << "Not Running";
    }else if(state==QProcess::Starting){
        qDebug() << "Starting";;
    }else{
        qDebug() << "Running";
    }
}

void MainWindow::showError()
{
    qDebug() << "showError:" << endl <

上面代码中我注释了很多语句,那是做测试用的,仅供参考使用.


运行效果如下:
QT开发之QProcess进程运行外部程序_第1张图片


                                                                                                                 文章出自:Linux_Google


你可能感兴趣的:(QT)