QT实现终端交互(Windows和Linux通用)
先看下效果,Windows下和Linux下都可以直接交互,输入命令直接回车即可!注意,Linux下需要先设置正确的密码才可以执行sudo命令!使用了多线程执行,所以执行命令时界面不卡顿!实时回显!Linux下:同一套代码,直接执行即可!声明代码供参考://author:autumoon//联系QQ:4589968//日期:2020-11-30#ifndef TERMINALINTERACTIVE_
·
先看下效果,Windows下和Linux下都可以直接交互,输入命令直接回车即可!
注意,Linux下需要先设置正确的密码才可以执行sudo命令!
使用了多线程执行,所以执行命令时界面不卡顿!实时回显!
Linux下:
同一套代码,直接执行即可!
Windows下可执行程序下载:https://autumoon.lanzoux.com/iSe5Rix1cuj
声明代码供参考:
//author:autumoon
//联系QQ:4589968
//日期:2020-11-30
#ifndef TERMINALINTERACTIVE_H
#define TERMINALINTERACTIVE_H
#include <QObject>
#include <QProcess>
#include <QThread>
#include <QMutex>
class TerminalInteractive : public QObject
{
Q_OBJECT
public:
explicit TerminalInteractive(const QString &strPwd, QObject *parent = nullptr);
public:
void Command(const QString& strCmd, const bool& bWaitForFinished = true);
Q_SIGNALS:
void readyReadStandardOutput(const QString& strStandardOutput);
void readyReadStandardError(const QString& strStandardError);
void finished();
private slots:
void on_readoutput();
void on_readerror();
private:
void initialize(const QString& strPwd = "");
private:
QString m_strPwd;
static QMutex m_mutex;
static QProcess *m_pCmd;
};
//启用线程执行
class TerminateWorker : public QObject
{
Q_OBJECT
public slots:
void doWork(const QString& strPwd, const QString& strCmd, const bool& bWaitForFinished)
{
/*耗时操作*/
TerminalInteractive *ti = new TerminalInteractive(strPwd);
connect(ti, SIGNAL(readyReadStandardOutput(const QString&)), this, SIGNAL(readyReadStandardOutput(const QString&)));
connect(ti, SIGNAL(readyReadStandardError(const QString&)), this, SIGNAL(readyReadStandardError(const QString&)));
connect(ti, SIGNAL(finished()), this, SIGNAL(finished()));
ti->Command(strCmd, bWaitForFinished);
}
Q_SIGNALS:
void readyReadStandardOutput(const QString& strStandardOutput);
void readyReadStandardError(const QString& strStandardError);
void finished();
};
class ThreadTerminate : public QObject
{
Q_OBJECT
QThread workerThread;
public:
ThreadTerminate()
{
TerminateWorker *worker = new TerminateWorker;
worker->moveToThread(&workerThread);
connect(&workerThread, &QThread::finished, worker, &QObject::deleteLater);
connect(worker, SIGNAL(readyReadStandardOutput(const QString&)), this, SIGNAL(readyReadStandardOutput(const QString&)));
connect(worker, SIGNAL(readyReadStandardError(const QString&)), this, SIGNAL(readyReadStandardError(const QString&)));
connect(worker, SIGNAL(finished()), this, SIGNAL(finished()));
connect(this, SIGNAL(start_command(const QString&, const QString&, const bool&)), worker, SLOT(doWork(const QString&, const QString&, const bool&)));
workerThread.start();
}
~ThreadTerminate()
{
workerThread.quit();
workerThread.wait();
}
public slots:
void Command(const QString& strPwd, const QString& strCmd, const bool& bWaitForFinished)
{
emit start_command(strPwd, strCmd, bWaitForFinished);
}
Q_SIGNALS:
void start_command(const QString& strPwd, const QString& strCmd, const bool& bWaitForFinished);
void readyReadStandardOutput(const QString& strStandardOutput);
void readyReadStandardError(const QString& strStandardError);
void finished();
};
#endif // TERMINALINTERACTIVE_H
欢迎交流与讨论!
更多推荐
所有评论(0)