QT笔记——QProcess学习

news2025/1/22 19:52:56

我们常常想通过某一个类,来启动一个外部进程

本文将讲解如何通过QProcess来进行启动外部进程

一:了解QProcess

QProcess是Qt框架提供的一个类,用于在应用程序中执行外部进程。它提供了一系列函数来启动、控制和与外部进程进行交互

1.启动进程的方式:
(1.1)分离式:外部程序启动程序后,主程序退出时,被调用的进程继续执行,不退出
请添加图片描述

[static] bool QProcess::startDetached(const QString &program, const QStringList &arguments, const QString &workingDirectory = QString(), qint64 *pid = nullptr)

(1.2)一体式:当主程序退出时,被主程序调用起来的进程也退出

start还有其他的重载的函数,下面是其中一个
请添加图片描述

void QProcess::start(const QString &program, const QStringList &arguments, QIODevice::OpenMode mode = ReadWrite)

2:常用的阻塞函数

// 主进程阻塞,直到外部程序启动完毕,
waitForStarted()
 
// 主进程阻塞,直到外部程序执行完毕
waitForFinished() 

3:被调用进程接受数据


4:主进程接受被调用进程的数据
(4.1)使用QFile输出内容被 主进程捕获

QFile file;
file.open(1, QFile::WriteOnly);
file.write("finished");
file.close();

(4.2)使用输出流 被 主进程捕获

 cout << "it's message" << endl;

5:常用的信号
请添加图片描述

//启动完毕
connect(process, &QProcess::started, this, [=]()
{
			
});

//捕获到消息时
connect(process, &QProcess::readyReadStandardOutput, this, [=]()
{

});

//完成
connect(process, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished), this, [=](int exitCode, QProcess::ExitStatus exitStatus)
{

});

//状态改变
connect(process, &QProcess::stateChanged, this, [=](QProcess::ProcessState state)
{
	
});

二:使用QPrecess

1:startDetached 启动进程

1:使用了startDetached来启动进程,信号都是无效的,接受不到任何消息
2:当主进程关闭时,被调用的QTcpClientTest.exe 是不会退出的
3:主进程发送的参数,被调用的QTcpClientTest.exe 依然可以接受

void QTcpSeverTest::on_btn1_clicked()
{
	QProcess* process = new QProcess(this);
	QString str = QApplication::applicationDirPath() + "/QTcpClientTest.exe";

	QStringList list;
	list.append("123");
	list.append("456");

	//分离式 启动外部进程
	process->startDetached(str, list);
	
	//无效
	connect(process, &QProcess::started, this, [=]()
		{
			qDebug() << "started";
		});

	//无效
	connect(process, &QProcess::readyReadStandardOutput, this, [=]()
		{
			QString qstr(process->readAllStandardOutput());
			qDebug() << "startDetached:" << qstr;
		});

	connect(process, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished), this, [=](int exitCode, QProcess::ExitStatus exitStatus)
		{
			QString result = process->readAll();
			qDebug() << "result:" << result;
		});

	//无效
	connect(process, &QProcess::stateChanged, this, [=](QProcess::ProcessState state)
		{
			qDebug() << "show state:";
			switch (state)
			{
			case QProcess::NotRunning:
				qDebug() << "Not Running";
				break;
			case QProcess::Starting:
				qDebug() << "Starting";
				break;
			case QProcess::Running:
				qDebug() << "Running";
				break;
			default:
				qDebug() << "otherState";
				break;
			}

		});

}

2:start启动进程

1:使用了startDetached来启动进程,信号都是可以接受的
2:当主进程关闭时,被调用的QTcpClientTest.exe 是随着主进程一起退出
3:主进程发送的参数,被调用的QTcpClientTest.exe 可以接受参数

	QProcess* process = new QProcess(this);
	QString str = QApplication::applicationDirPath() + "/QTcpClientTest.exe";

	QStringList list;
	list.append("bbbbb");
	list.append("aaaaa");

	//启动完毕
	connect(process, &QProcess::started, this, [=]()
	{
			qDebug() << "started:" ;
	});

	//捕获到消息时
	connect(process, &QProcess::readyReadStandardOutput, this, [=]()
	{
			QString qstr(process->readAllStandardOutput());
			qDebug() << "readyReadStandardOutput:" << qstr;
	});

	//完成
	connect(process, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished), this, [=](int exitCode, QProcess::ExitStatus exitStatus)
	{
			if (exitStatus == QProcess::NormalExit) {
				qDebug() << "Process finished with exit code:" << exitCode;
			}
			else {
				qDebug() << "Process crashed!";
			}
	});

	//状态改变
	connect(process, &QProcess::stateChanged, this, [=](QProcess::ProcessState state)
	{
			qDebug() << "show state:";
			switch (state)
			{
			case QProcess::NotRunning:
				qDebug() << "Not Running";
				break;
			case QProcess::Starting:
				qDebug() << "Starting";
				break;
			case QProcess::Running:
				qDebug() << "Running";
				break;
			default:
				qDebug() << "otherState";
				break;
			}

	});

	//一体式  启动外部进程
	process->start(str, list);

3:execute()启动进程

1:使用了execute来启动进程,信号是无效的
2:主进程一直处于阻塞状态,等待被调用的QTcpClientTest.exe完成(关闭软件)

	QProcess* process = new QProcess(this);
	QString str = QApplication::applicationDirPath() + "/QTcpClientTest.exe";

	QStringList list;
	list.append("bbbbb");
	list.append("aaaaa");

	//无效
	connect(process, &QProcess::started, this, [=]()
		{
			qDebug() << "started:";
		});

	//无效
	connect(process, &QProcess::readyReadStandardOutput, this, [=]()
		{
			QString qstr(process->readAllStandardOutput());
			qDebug() << "readyReadStandardOutput:" << qstr;
		});

	//无效
	connect(process, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished), this, [=](int exitCode, QProcess::ExitStatus exitStatus)
		{
			QString result = process->readAll();
			qDebug() << "result:" << result;
		});

	//无效
	connect(process, &QProcess::stateChanged, this, [=](QProcess::ProcessState state)
		{
			qDebug() << "show state:";
			switch (state)
			{
			case QProcess::NotRunning:
				qDebug() << "Not Running";
				break;
			case QProcess::Starting:
				qDebug() << "Starting";
				break;
			case QProcess::Running:
				qDebug() << "Running";
				break;
			default:
				qDebug() << "otherState";
				break;
			}

		});

	//如果进程 QTcpClientTest 不关闭 或者完成 , 则此进程一直卡住
	int exitCode = QProcess::execute(str, list);
	if (exitCode != 0) {
		qDebug() << "外部程序执行失败";
	}

	//接受进程捕获到输出的消息
	QByteArray output = process->readAllStandardOutput();
	QString msg = QString::fromLocal8Bit(output);
	qDebug() << msg;

打印的信息为:QIODevice::read (QProcess): device not open,说明execute没有打开设备,接受不到消息

4:start() + waitForFinished()启动进程

1:使用了execute来启动进程,信号是无效的
2:主进程一直处于阻塞状态,等待被调用的QTcpClientTest.exe完成(关闭软件)

	QProcess* process = new QProcess(this);
	QString str = QApplication::applicationDirPath() + "/QTcpClientTest.exe";

	QStringList list;
	list.append("bbbbb");
	list.append("aaaaa");

	//启动进程
    process->start(str,list);

    // 等待进程完成
    process->waitForFinished();

	//接受进程捕获到输出的消息
    QByteArray output = process->readAllStandardOutput();
    QString msg = QString::fromLocal8Bit(output);
    qDebug() << msg;

完整代码:
QProcess完整学习代码

参考博客:
QProcess使用 一
QProcess使用 二
QProcess使用 三
QProcess使用 四

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/883482.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

02 基于51单片机的LED闪烁实验

目录 前言 一、整体目录结构 二、代码展示 三、main.c代码解析 四、下载到单片机中 总结 前言 前面我们已经学会了点亮一个led的实验&#xff0c;今天我们来实现LED闪烁。前面我们讲到想要让LED亮的话&#xff0c;只要给单片机引脚高电平就好了&#xff0c;如果给LED低电平的话…

Flink之Task解析

Flink之Task解析 对Flink的Task进行解析前,我们首先要清楚几个角色TaskManager、Slot、Task、Subtask、TaskChain分别是什么 角色注释TaskManager在Flink中TaskManager就是一个管理task的进程,每个节点只有一个TaskManagerSlotSlot就是TaskManager中的槽位,一个TaskManager中可…

Vue2-配置脚手架、分析脚手架、render函数、ref属性、props配置项、mixin配置项、scoped样式、插件

&#x1f954;:总有一段付出了没有回报的日子 是在扎根 更多Vue知识请点击——Vue.js VUE2-Day6 配置脚手架脚手架结构render函数vue.js与vue.runtime.xxx.js的区别引入render函数为什么要引入残缺的vue呢&#xff1f; 脚手架默认配置ref属性props配置项传递数据接收数据注意点…

elementui form组件出现英文提示

今天让解决一个bug&#xff0c;是表单组件提示词会出现英文。 问题情景如下&#xff1a; 有时会出现中文&#xff0c;有时会出现英文。 解决方法&#xff1a; 经查看&#xff0c;代码采用的是elementui的form组件&#xff0c;在el-form-item中使用了required属性&#xff0c;同…

企业权限管理(十)-用户详情

用户详情 UserController findById方法 Controller RequestMapping("/user") public class UserController {Autowiredprivate IUserService userService;//查询指定id的用户RequestMapping("/findById.do")public ModelAndView findById(String id) thro…

Python面向对象进阶教程,Python面向对象进阶知识笔记

类方法、静态方法 1. 类方法 第一个形参是类对象的方法需要用装饰器classmethod来标识其为类方法&#xff0c;对于类方法&#xff0c;第一个参数必须是类对象&#xff0c;一般以cls作为第一个参数。 class Dog(object): __type "狗" # 类方法&#xff0c;用class…

数据结构中公式前中后缀表达式-二叉树应用

目录 数据结构中公式前中后缀表达式-二叉树应用 数据结构中公式前中后缀表达式-二叉树应用 什么是前缀表达式、中缀表达式、后缀表达式 前缀表达式、中缀表达式、后缀表达式&#xff0c;是通过树来存储和计算表达式的三种不同方式 以如下公式为例 通过树来存储该公式&#x…

Avalonia 11 WebAssembly中文乱码

文章目录 0x00 原因0x01 解决方法FontForge 0x02 使用自定义字体App.axaml控件使用效果 0x00 原因 新建的Avalonia 11 WebAssembly项目&#xff0c;直接运行的话&#xff0c;会发现中文都是乱码&#xff0c;并且直接在控件上修改FontFamily属性是无法生效的。 0x01 解决方法…

MySQL学习笔记 - 进阶部分

MySQL进阶部分 字符集的相关操作&#xff1a;字符集和比较规则&#xff1a;utf8与utf8mb4&#xff1a;比较规则&#xff1a;常见的字符集和对应的Maxlen&#xff1a; Centos7中linux下配置字符集&#xff1a;各个级别的字符集&#xff1a;执行show variables like %character%语…

matlab画图中多个图例分开绘制

在matlab绘图中&#xff0c;线条较多时导致图例较长回遮挡原图/将图例分类&#xff0c;解决方案将图例分为多个。 一、多个图例一起显示 r 10; a 0; b 0; t0:0.1:2.1*pi; xar*cos(t); ybr*sin(t); plot(x,y,r,linewidth,4);hold on axis equal plot([0 0],[1 10],b,linewi…

双碳目标下基于“遥感+”多技术融合在碳储量、碳排放、碳循环、温室气体等领域应用教程

详情点击链接&#xff1a;双碳目标下基于“遥感”多技术融合在碳储量、碳排放、碳循环、温室气体等领域应用教程 一&#xff1a;双碳视角下遥感技术的研究方向 1.双碳背景及遥感的现实需求 2.全球碳库、碳收支及碳循环现状 3.碳储量、碳收支与碳循环中的遥感技术 4.ENVI及ArcG…

海龟绘图——n个正方形组成的图案

运行结果&#xff1a; 代码&#xff1a; import turtle# 创建海龟对象 nint(input()) t turtle.Turtle()# 设置海龟的颜色和线条粗细 t.color(blue) t.pensize(3)# 画四条直线lengths10 for j in range(n):for i in range(4):lengths20t.forward(lengths)# 旋转90度t.left(90)…

数据治理:打造可信赖的BI环境

章节一&#xff1a;引言 随着信息时代的不断发展&#xff0c;数据已经成为企业决策的重要支撑。而在大数据时代&#xff0c;海量的数据需要被整理、分析&#xff0c;以便为企业提供正确的指导。商业智能&#xff08;BI&#xff09;系统的兴起为企业提供了强大的数据分析能力&am…

利用Lifecycle,管理一个计时器生命周期

Lifecycle是Android Jetpack中的一个组件&#xff0c;用于管理Android应用程序组件&#xff08;如Activity或Fragment&#xff09;的生命周期。它可以帮助开发者在不同的生命周期阶段执行特定的操作&#xff0c;以便更好地管理资源、处理数据和提供用户体验。 Lifecycle作用 …

Python程序设计——对象和类

学习目标 描述对象和类&#xff0c;以及使用类来建模对象定义带数据域和方法的类使用构造方法调用初始化程序来创建和初始化数据域以构建一个对象使用圆点运算符(.)访问对象成员使用self参数引用对象本身使用UML图符号来描述类和对象区分不可变对象和可变对象隐藏数据域以避免数…

应届生运维简历攻略

导语&#xff1a; 当下&#xff0c;计算机科学与技术已经成为一个炙手可热的行业&#xff0c;而作为这个行业中的一份子&#xff0c;运维人员的角色无疑至关重要。如果你是一位即将毕业的应届生&#xff0c;并希望在运维领域打拼&#xff0c;那么一份出色的运维简历将是你踏入…

PS常用快捷按键

1、Ctrl J 键复制&#xff08;快速复制图层&#xff0c;作为备份&#xff09;&#xff1b; 2、快速选择对象&#xff0c;进行移动ctrl 右键 3、放大ctrl 缩小ctrl 4、对同一个图片的多个不同颜色的图片进行截取的时候&#xff0c;注意每次都用同一个切图框&#xff0c;截图保…

【C++】stack容器

1.stack基本概念 英stk 美stk n.&#xff08;整齐的&#xff09;一堆&#xff1b;<英> 垛&#xff0c;堆&#xff1b;大量&#xff0c;许多&#xff1b;&#xff08;尤指工厂的&#xff09;大烟囱&#xff1b;&#xff08;图书馆的&#xff09;藏书架&#xff0c;双面书架…

Redis实现共享Session

Redis实现共享Session 分布式系统中&#xff0c;sessiong共享有很多的解决方案&#xff0c;其中托管到缓存中应该是最常用的方案之一。 1、引入依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM…

Linux:shell脚本 正则表达式与AWK

一、正则表达式 由一类特殊字符及文本字符所编写的模式&#xff0c;其中有些字符&#xff08;元字符&#xff09;不表示字符字面意义&#xff0c;而表示控制或通配的功能&#xff0c;类似于增强版的通配符功能&#xff0c;但与通配符不同&#xff0c;通配符功能是用来处理文件…