C++每日训练 Day 17:构建响应式加载动画与异步数据处理

📘 本篇目标是:在 GUI 信号机制基础上,构建一个完整的“点击按钮 → 显示加载动画 → 异步加载数据 → 显示结果”的响应式界面流程。通过协程挂起/恢复机制,实现清晰的异步逻辑,避免回调地狱。


🔁 回顾 Day 16:GUI 响应式信号机制

在 Day 16 中,我们学习了如何使用协程和信号机制处理 GUI 事件。主要内容包括:

  • 按钮点击事件的处理:通过协程挂起,等待按钮点击事件的发生,然后恢复协程执行相应的逻辑。
  • 信号机制的实现:使用 SignalHub 类管理不同的事件类型,实现事件的订阅和触发。
  • 协程与 Dispatcher 的结合:确保协程的恢复在正确的线程中执行,避免线程安全问题。

这些基础为我们今天的内容打下了坚实的基础。


在这里插入图片描述

✅ 一、模拟加载动画组件

我们首先创建一个简单的加载动画组件,用于在数据加载期间显示加载状态。

struct LoadingSpinner {void show() {std::cout << "🔄 显示加载动画...\n";}void hide() {std::cout << "✅ 隐藏加载动画\n";}
};

✅ 二、构建异步数据加载器

接下来,创建一个模拟异步加载数据的函数,使用协程实现。

Task<std::string> loadDataAsync() {co_await std::suspend_always{}; // 模拟异步等待std::this_thread::sleep_for(std::chrono::seconds(2)); // 模拟加载时间co_return "数据加载完成";
}

✅ 三、构建按钮点击事件处理协程

我们创建一个协程函数,处理按钮点击事件,显示加载动画,加载数据,并在加载完成后更新界面。

Task<void> onButtonClick(LoadingSpinner& spinner) {spinner.show(); // 显示加载动画std::string data = co_await loadDataAsync(); // 异步加载数据spinner.hide(); // 隐藏加载动画std::cout << "📦 加载结果: " << data << "\n";co_return;
}

✅ 四、主函数模拟用户点击按钮

在主函数中,模拟用户点击按钮,触发上述协程。

int main() {LoadingSpinner spinner;std::cout << "🖱️ 用户点击按钮\n";auto task = onButtonClick(spinner); // 启动协程处理按钮点击事件// 模拟事件循环while (!task.done()) {task.resume(); // 恢复协程执行}return 0;
}

输出:

🖱️ 用户点击按钮
🔄 显示加载动画...
✅ 隐藏加载动画
📦 加载结果: 数据加载完成

✅ 总结

通过以上步骤,我们实现了一个完整的响应式界面流程,使用协程清晰地表达了异步逻辑,避免了传统回调方式带来的复杂性。


🧠 巩固练习题

Q1:如何确保协程 resume 在主线程执行?
A:使用主线程的 Dispatcher,在协程挂起时记录 Dispatcher,resume 时通过 Dispatcher 调度回主线程。

Q2:如何处理多个按钮点击事件?
A:为每个按钮创建独立的协程处理函数,分别处理各自的点击事件。

Q3:如何处理加载失败的情况?
A:在 loadDataAsync 中添加异常处理逻辑,在协程中使用 try-catch 捕获异常,进行相应的错误处理。


🔭 下一步 Day 18:构建响应式表单与数据验证

  • 创建响应式表单组件
  • 使用协程处理表单输入与验证
  • 实现异步提交与结果反馈

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

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

相关文章

PyTorch深度学习框架60天进阶学习计划 - 第45天:神经架构搜索(二)

PyTorch深度学习框架60天进阶学习计划 - 第45天&#xff1a;神经架构搜索&#xff08;二&#xff09; 第二部分&#xff1a;权重共享策略的计算效率优化 8. 权重共享的理论基础 权重共享策略的理论基础来自于多任务学习(Multi-Task Learning, MTL)和迁移学习(Transfer Learn…

深入理解分布式缓存 以及Redis 实现缓存更新通知方案

一、分布式缓存简介 1. 什么是分布式缓存 分布式缓存&#xff1a;指将应用系统和缓存组件进行分离的缓存机制&#xff0c;这样多个应用系统就可以共享一套缓存数据了&#xff0c;它的特点是共享缓存服务和可集群部署&#xff0c;为缓存系统提供了高可用的运行环境&#xff0c…

记录学习的第二十九天

还是力扣每日一题。 本来想着像昨天一样两个循环搞定的&#xff0c;就下面&#x1f447;&#x1f3fb; 不过&#xff0c;结果肯定是超时啦&#xff0c;中等题是吧。 正确答案是上面的。 之后就做了ls题单第一部分&#xff0c;首先是定长滑窗问题 这种题都是有套路的&#xff0…

Win11关闭防火墙方法

网上讲的win11的方法都试过了&#xff0c;但是在实际使用过程中还是会显示有威胁杀掉原本要使用的程序&#xff0c;下面我介绍的这个方法亲测有效&#xff0c;必须百分百关掉防火墙 搜索安全中心打开Windows安全中心 打开病毒和威胁防护 点击管理设置 将设置中所有显示开的都…

几个常用的快速处理服务器命令和故障排查

1. 查看剩余的内存 free -m top //当然了还有top可以实时观测 显示剩余内存,以M为单位. 2. 查看剩余的空间 df -h 显示指定磁盘文件的可用空间。如果没有文件名被指定&#xff0c;则所有当前被挂载的文件系统的可用空间将被显示 3.找出大文件的常用方法 du --max-depth1 -h –输…

Spring MVC 全栈指南:RESTful 架构、核心注解与 JSON 实战解析

目录 RESTful API 设计规范Spring MVC 核心注解解析静态资源处理策略JSON 数据交互全解高频问题与最佳实践 一、RESTful API 设计规范 1.1 核心原则 原则说明示例 URI资源为中心URI 使用名词&#xff08;复数形式&#xff09;/users ✔️ /getUser ❌HTTP 方法语义化GET&…

探索 JavaScript 中的 Promise 高级用法与实战

在现代 Web 开发中&#xff0c;异步编程已成为不可或缺的一部分。JavaScript 作为 Web 开发的核心语言&#xff0c;提供了多种处理异步操作的方式&#xff0c;其中 Promise 对象因其简洁、强大的特性而备受青睐。本文将深入探讨 Promise 的高级用法&#xff0c;并结合实际案例&…

《软件设计师》复习笔记(14.1)——面向对象基本概念、分析设计测试

目录 一、面向对象基本概念 对象&#xff08;Object&#xff09; 类&#xff08;Class&#xff09; 抽象&#xff08;Abstraction&#xff09; 封装&#xff08;Encapsulation&#xff09; 继承&#xff08;Inheritance&#xff09; 多态&#xff08;Polymorphism&#…

ubuntu22.04 安装有度即时通

1.官网下载deb的安装包 官网地址&#xff1a;有度客户端下载-有度 注意&#xff1a;这个网站的下载是有时间限制的&#xff0c;有时候无法下载 需要对应系统版本&#xff0c;否则无法使用 我之前使用了dpkg安装了一个旧版本&#xff0c;卸载使用以下命名行&#xff1a; 使用…

ValueError: model.embed_tokens.weight doesn‘t have any device set

ValueError: model.embed_tokens.weight doesn’t have any device set model.embed_tokens.weight 通常在深度学习框架(如 PyTorch)中使用,一般是在处理自然语言处理(NLP)任务时,用于指代模型中词嵌入层(Embedding layer)的权重参数。下面详细解释: 词嵌入层的作用 …

如何提高单元测试的覆盖率

一、定位未覆盖的代码 ​利用 IDEA 的覆盖率工具​&#xff1a; 右键测试类 → ​Run with Coverage&#xff0c;或使用 AltShiftF10&#xff08;Windows&#xff09;打开运行菜单选择覆盖率。​查看高亮标记​&#xff1a; ​绿色​&#xff1a;已覆盖代码行。​红色​&#x…

聚合直播-Simple Live-v1.7.7-全网直播平台能在一个软件上看完

聚合直播-Simple Live 链接&#xff1a;https://pan.xunlei.com/s/VOO7u3o4FNL_XA9VJ6l7KBNfA1?pwdyrau# 聚合直播-Simple Live-v1.7.7-全网直播平台能在一个软件上看完

三大等待和三大切换

三大等待 1、三大等待&#xff1a;等待的方式有三种&#xff1a;强制等待&#xff0c;隐性等待&#xff0c;显性等待。 1、强制等待&#xff1a;time.sleep(2)&#xff0c;秒 优点&#xff1a;使用简单缺点&#xff1a;等待时间把握不准&#xff0c;容易造成时间浪费或者等待时…

使用Lombok @Builder 收参报错提示没有无参构造方法的原因与解决办法

使用Lombok Builder 收参报错提示没有无参构造方法的原因与解决办法 类上加了Builder之后接口接收前端传来的参数报错&#xff1a;(no Creators, like default constructor, exist): cannot deserialize from Object value (no delegate- or property-based Creator) 1.解决办法…

SAP 查找JOB进程ID

如何查找后台JOB的进程ID SM37勾选对于JOB

通过C# 将Excel表格转换为图片(JPG/ PNG)

Excel 表格可能会因为不同设备、不同软件版本或字体缺失等问题&#xff0c;导致格式错乱或数据显示异常。转换为图片后&#xff0c;能确保数据的排版、格式和外观始终保持一致&#xff0c;无论在何种设备或平台上查看&#xff0c;都能呈现出固定的样式&#xff0c;避免了因环境…

Langchain构建RAG对话应用

本文&#xff1a;关注 检索器与上下文的子链、父链&#xff1b;即检索器也需要上下文内容。 RAG是一种增强LLM知识的方法&#xff0c;通过引入额外的数据来实现。 实现思路&#xff1a;加载—》分割—》存储—》检索—》生成。 初始化 import os import bs4 from langchain.c…

关于模拟噪声分析的11个误区

目录 1. 降低电路中的电阻值总是能改善噪声性能 2. 所有噪声源的噪声频谱密度可以相加&#xff0c;带宽可以在最后计算时加以考虑 3. 手工计算时必须包括每一个噪声源 4. 应挑选噪声为ADC 1/10的ADC驱动器 5. 直流耦合电路中必须始终考虑1/f噪声 6. 因为1/f噪声随着频率降…

vue,uniapp解决h5跨域问题

如果有这样的跨域问题&#xff0c;解决办法&#xff1a; ✅ 第一步&#xff1a;在项目根目录下创建 vue.config.js 和 package.json 同级目录。 // vue.config.js module.exports {devServer: {proxy: {/api: {target: https://app.yycjkb.cn, // 你的后端接口地址changeOrig…

SQL通用语法和注释,SQL语句分类(DDL,DML,DQL,DCL)及案例

目录 SQL通用语法和注释 SQL语句分类&#xff08;DDL&#xff0c;DML&#xff0c;DQL&#xff0c;DCL&#xff0c;TPL&#xff0c;CCL&#xff09; DDL&#xff08;数据定义语言&#xff09; 数据库操作 查询&#xff08;SHOW、SELECT&#xff09; 创建&#xff08;CREAT…