我可以使用以下命令运行外部应用程序:
system("/home/felippe/Área\\ de\\ Trabalho/Felippe/Mestrado/C_plus_plus/Codigos/build-Registration_ITK_CMAKE-Desktop_Qt_5_12_3_GCC_64bit-Default/Registration_ITK_CMAKE")
该应用程序成功运行。但是system(。)命令会阻止其他命令,直到应用程序完成。因此,我尝试使用以下代码在QT中实现此命令:
.h
#ifndef FOO_H
#define FOO_H
#include <QObject>
#include <iostream>
#include <QProcess>
class foo : public QObject
{
Q_OBJECT
public:
explicit foo(QObject *parent = nullptr);
signals:
public slots:
void process_started();
void processError(QProcess::ProcessError error);
private:
QProcess *process;
};
#endif // FOO_H
.cpp
#include "foo.h"
foo::foo(QObject *parent) : QObject(parent)
{
process = new QProcess();
bool status = QObject::connect( process, SIGNAL( started() ), this, SLOT( process_started() ) );
connect(process, &QProcess::errorOccurred, this, &foo::processError);
QString file = "/home/felippe/Área de Trabalho/Felippe/Mestrado/C_plus_plus/Codigos/build-Registration_ITK_CMAKE-Desktop_Qt_5_12_3_GCC_64bit-Default/Registration_ITK_CMAKE";
process->start(file);
std::cout << file.toStdString() << std::endl;
std::cout << "status: " << status << std::endl;
}
void foo::process_started()
{
std::cout << "It worked" << std::endl;
}
void foo::processError(QProcess::ProcessError error)
{
std::cout << "error enum val = " << error << std::endl;
}
主要
#include <QCoreApplication>
#include <iostream>
#include "foo.h"
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
foo *f = new foo();
return a.exec();
}
当我运行process-> start(file);我收到一个值为0的错误,但是当我运行process-> start(file,{“ sudo”});我收到一个信号,表明程序已成功运行,但是屏幕上仍显示任何内容。
我正在尝试在UBUNTU 16.04上运行。
那么,怎么回事?
答案 0 :(得分:1)
最明显的区别是system
将您的字符串传递给shell,而QProcess::start
则分别获取命令和参数列表。
我敢打赌,如果您钩住errorOccurred
信号,您将得到“找不到文件”。
解决方案:从字符串中删除\\
,因为只有在涉及shell时才需要使用它们。