前言
QT调用后台命令行,通常有两种场景:执行命令,等待并获取返回结果;执行命令,让程序后台一直执行(孤儿进程),不需要获取命令返回的结果。以下是分享在国产信创桌面操作系统(麒麟kylin、统信UOS)下的解决方法。
功能讲解
1、执行命令,等待并获取返回结果
【QT常用技术讲解】多线程编程处理卡顿_qt 为文件读取移动到线程中处理就非常慢-CSDN博客
在此篇文章中分享了调用后台ping命令,并获取结果的方法,在Linux系统中也是可以的,当我使用此代码执行需要后台一直运行的程序的时候,发现进程会被杀死,并报如下错误
QProcess: Destroyed while process ("bash") is still running.
主要原因是线程资源被回收导致执行的进程被杀死。做了一些小改动尝试,还是报如下错误:
QObject: Cannot create children for a parent that is in a different thread.
(Parent is QProcess(0x1f2fc60), parent's thread is QThread(0x1eea6b0), current thread is ThreadShellCmd(0x1f2bd40)
存在父子进程的问题(其实第三方程序已经创建成功了,不确定是否稳定,所以另外写代码来实现了)。
2、执行命令,让程序后台一直执行
需要使用QProcess::startDetached()对进程进行完全分离即可。代码如下所示
//threadNohupCmd.h
#ifndef THREADNOHUPCMD_H
#define THREADNOHUPCMD_H
#include <QThread>
#include <QString>
#include <QProcess>
class ThreadNohupCmd : public QThread
{
Q_OBJECT
public:
explicit ThreadNohupCmd(const QString ¶m,QObject *parent = nullptr) ;
~ThreadNohupCmd();
protected:
void run() override;
signals:
void callback(const QString result);
private:
QString m_param;
};
#endif // THREADNOHUPCMD_H
//threadNohupCmd.cpp
#ifndef THREADNOHUPCMD_CPP
#define THREADNOHUPCMD_CPP
#include "threadNohupCmd.h"
#include <QDebug>
ThreadNohupCmd::ThreadNohupCmd(const QString ¶m,QObject *parent) : QThread(parent),m_param(param) {
}
ThreadNohupCmd::~ThreadNohupCmd() {
}
void ThreadNohupCmd::run(){
QString cmd = m_param;
QProcess process;
process.setProcessChannelMode(QProcess::MergedChannels);
process.startDetached("bash", QStringList() << "-c" << cmd);
emit callback("[success] 已后台执行");
}
#endif // THREADNOHUPCMD_CPP
调用方式与1是一样的。