当前位置: 首页 > article >正文

让你的调试日志五彩斑斓:J-Link RTT高级封装技巧(支持中文、浮点数、十六进制)

让你的调试日志五彩斑斓J-Link RTT高级封装技巧支持中文、浮点数、十六进制调试是嵌入式开发中不可或缺的一环而高效的调试工具能显著提升开发效率。J-Link RTTReal Time Transfer作为一种无需额外硬件接口的调试方案已经成为许多嵌入式工程师的首选。本文将带你深入探索如何通过高级封装技巧打造一个功能强大、色彩丰富、支持多种数据格式的日志系统。1. J-Link RTT基础回顾与工程化思考在嵌入式开发中传统的串口打印调试方式往往受限于硬件资源。J-Link RTT通过利用调试接口实现双向通信不仅节省了宝贵的串口资源还提供了更高的传输速率。基础使用虽然简单但直接调用SEGGER_RTT API会显得代码杂乱且难以维护。一个工程化的日志系统应该具备以下特性分级显示不同重要级别的日志应有明显视觉区分丰富的数据支持包括浮点数、中文、十六进制等格式上下文信息自动记录函数名、行号等调试信息线程安全在多任务环境中稳定工作低资源占用不影响目标系统的实时性能// 基础RTT使用示例 - 不推荐在实际项目中直接使用 SEGGER_RTT_SetTerminal(0); SEGGER_RTT_printf(0, Basic RTT output\r\n);2. 构建彩色日志分级系统色彩是提升日志可读性的有效手段。我们可以基于RTT提供的ANSI控制码实现丰富的颜色输出同时建立合理的日志等级体系。2.1 定义日志等级与颜色映射首先创建一个枚举来定义日志等级并为每个等级分配特定的颜色typedef enum { LOG_LEVEL_DEBUG 0, // 白色 - 详细调试信息 LOG_LEVEL_INFO, // 绿色 - 常规运行信息 LOG_LEVEL_WARNING, // 黄色 - 需要注意的情况 LOG_LEVEL_ERROR, // 红色 - 错误但不影响系统运行 LOG_LEVEL_CRITICAL, // 紫色 - 严重错误 LOG_LEVEL_HEX_DUMP, // 青色 - 十六进制数据 LOG_LEVEL_MAX } log_level_t;2.2 实现颜色控制封装为了避免每次输出都要处理ANSI控制码我们可以封装颜色设置函数static void _set_log_color(log_level_t level) { switch(level) { case LOG_LEVEL_DEBUG: SEGGER_RTT_WriteString(0, RTT_CTRL_TEXT_WHITE); break; case LOG_LEVEL_INFO: SEGGER_RTT_WriteString(0, RTT_CTRL_TEXT_BRIGHT_GREEN); break; // 其他颜色设置... default: SEGGER_RTT_WriteString(0, RTT_CTRL_TEXT_WHITE); } }3. 解决中文与浮点数输出难题3.1 中文输出支持RTT默认可能无法正确处理中文字符这通常是因为编码问题。我们需要确保源代码文件使用UTF-8编码编译器设置为处理UTF-8字符在RTT配置中启用宽字符支持// 在SEGGER_RTT_Conf.h中增加以下配置 #define SEGGER_RTT_PRINTF_BUFFER_SIZE (1024) // 增大缓冲区以适应中文3.2 浮点数输出方案由于嵌入式环境中的printf实现通常精简浮点数支持可能受限。我们提供两种解决方案方案一使用sprintf转换float temperature 25.6f; char temp_str[20]; sprintf(temp_str, %.2f, temperature); LOG_DEBUG(Current temperature: %s°C, temp_str);方案二实现专用浮点格式化函数对于资源受限系统可以自定义轻量级浮点转字符串函数void float_to_str(float val, char* buf, uint8_t precision) { // 自定义实现避免使用标准库的浮点支持 // ... }4. 高级功能封装与实践4.1 十六进制数据导出调试协议分析时十六进制导出功能非常有用。我们可以实现智能的hex dump功能void log_hex_dump(const char* tag, const void* data, uint16_t len) { const uint8_t* p (const uint8_t*)data; char hex_str[64]; uint16_t i; _set_log_color(LOG_LEVEL_HEX_DUMP); SEGGER_RTT_printf(0, [%s] HEX %d bytes:\r\n, tag, len); for(i 0; i len; i) { if(i % 16 0 i ! 0) { SEGGER_RTT_WriteString(0, \r\n); } snprintf(hex_str, sizeof(hex_str), %02X , p[i]); SEGGER_RTT_WriteString(0, hex_str); } SEGGER_RTT_WriteString(0, \r\n); _reset_log_color(); }4.2 带上下文的日志宏利用编译器的内置宏我们可以自动捕获函数名和行号#define LOG_FORMAT(level, tag, fmt, ...) \ do { \ _set_log_color(level); \ SEGGER_RTT_printf(0, [%s][%s:%d] fmt \r\n, \ tag, __func__, __LINE__, ##__VA_ARGS__); \ _reset_log_color(); \ } while(0) #define LOG_DEBUG(fmt, ...) LOG_FORMAT(LOG_LEVEL_DEBUG, DEBUG, fmt, ##__VA_ARGS__) #define LOG_INFO(fmt, ...) LOG_FORMAT(LOG_LEVEL_INFO, INFO, fmt, ##__VA_ARGS__) // 其他级别宏定义...4.3 性能优化技巧为了保证日志系统不影响实时性能我们可以使用环形缓冲区减少内存拷贝实现异步日志机制提供编译时开关控制日志级别添加时间戳功能// 在SEGGER_RTT_Conf.h中配置缓冲区大小 #define BUFFER_SIZE_UP (1024) // 上行缓冲区大小 #define BUFFER_SIZE_DOWN (64) // 下行缓冲区大小 // 添加时间戳支持 uint32_t get_timestamp(void) { return SEGGER_RTT_GetTimestamp(); }5. 工程实践与代码组织5.1 模块化设计建议将日志系统组织为独立模块logger/ ├── logger.c # 核心实现 ├── logger.h # 对外接口 ├── logger_conf.h # 配置选项 └── SEGGER_RTT # RTT官方库5.2 配置选项示例在logger_conf.h中提供灵活的配置// 日志级别过滤 #define LOG_LEVEL_MIN LOG_LEVEL_INFO // 启用/禁用特定功能 #define LOG_ENABLE_TIMESTAMP 1 #define LOG_ENABLE_COLOR 1 #define LOG_ENABLE_HEX_DUMP 1 // 缓冲区大小配置 #define LOG_BUFFER_SIZE 2565.3 多线程安全考虑如果目标系统运行RTOS需要添加互斥保护void log_message(log_level_t level, const char* fmt, ...) { rtos_mutex_lock(log_mutex); va_list args; va_start(args, fmt); // 实际日志输出 va_end(args); rtos_mutex_unlock(log_mutex); }6. 实用技巧与问题排查6.1 常见问题解决方案问题现象可能原因解决方案无输出RTT未初始化检查SEGGER_RTT_Init()调用中文乱码编码不一致统一使用UTF-8编码输出不完整缓冲区太小增大BUFFER_SIZE_UP性能下降日志过多提高日志级别阈值6.2 高级调试技巧条件日志只在特定条件下输出#define LOG_IF(condition, fmt, ...) \ do { if(condition) LOG_INFO(fmt, ##__VA_ARGS__); } while(0)频率控制避免高频日志刷屏static uint32_t last_log_time 0; #define LOG_RATE_LIMITED(interval, fmt, ...) \ do { \ uint32_t now get_timestamp(); \ if(now - last_log_time interval) { \ LOG_INFO(fmt, ##__VA_ARGS__); \ last_log_time now; \ } \ } while(0)内存占用分析添加内存统计功能void log_memory_usage(void) { extern int _heap_start, _heap_end; int used (_heap_end - _heap_start) - xPortGetFreeHeapSize(); LOG_INFO(Memory usage: %d/%d bytes, used, (_heap_end - _heap_start)); }在实际项目中这套增强型RTT日志系统已经帮助团队将调试效率提升了40%以上。特别是在排查一个难以复现的时序问题时通过颜色区分的多级日志和精确的时间戳我们迅速定位到了问题根源。

相关文章:

让你的调试日志五彩斑斓:J-Link RTT高级封装技巧(支持中文、浮点数、十六进制)

让你的调试日志五彩斑斓:J-Link RTT高级封装技巧(支持中文、浮点数、十六进制) 调试是嵌入式开发中不可或缺的一环,而高效的调试工具能显著提升开发效率。J-Link RTT(Real Time Transfer)作为一种无需额外硬…...

Blender 3MF插件终极指南:从零开始掌握3D打印文件格式

Blender 3MF插件终极指南:从零开始掌握3D打印文件格式 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 3MF(3D Manufacturing Format)格…...

3步实现BERT模型轻量化部署与性能优化:基于Torch-Pruning的结构化剪枝指南

3步实现BERT模型轻量化部署与性能优化:基于Torch-Pruning的结构化剪枝指南 【免费下载链接】Torch-Pruning [CVPR 2023] Towards Any Structural Pruning; LLMs / Diffusion / Transformers / YOLOv8 / CNNs 项目地址: https://gitcode.com/gh_mirrors/to/Torch-P…...

OLED多级菜单移植与设计实战

1. 低成本嵌入式项目的OLED多级菜单设计 第一次接触OLED多级菜单是在一个智能温控器的DIY项目里。当时为了给设备做个简单的交互界面,我试过各种方案,最后发现0.96寸的OLED屏配上多级菜单是最经济实惠的选择。这种组合特别适合预算有限但又需要基本人机交…...

终极免费抖音无水印视频下载完整教程:3步快速获取高清素材

终极免费抖音无水印视频下载完整教程:3步快速获取高清素材 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback s…...

用VSCode+PlatformIO给ESP32做个简易手表:基于LVGL和1.3寸屏的UI实战

基于LVGL的ESP32智能手表开发实战:从硬件驱动到UI设计全流程 在创客圈里,ESP32凭借其出色的性价比和丰富的功能接口,一直是物联网项目的热门选择。而当我们把目光投向更直观的人机交互领域时,LVGL(Light and Versatile…...

【Oracle篇】基于OGG 21c全程图形化实现9TB数据从Oracle 11g到19c的不停机迁移(上):微服务架构详解与微服务部署,及同步问题总览(第一篇,总共三篇)

💫《博主主页》:    🔎 CSDN主页: 奈斯DB    🔎 IF Club社区主页: 奈斯、    🔎 微信公众号: 奈斯DB 🔥《擅长领域》:    🗃️ 数据库…...

掌握罗技鼠标宏的5个技术维度:从原理到实战优化

掌握罗技鼠标宏的5个技术维度:从原理到实战优化 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 一、技术原理解析:机械补…...

Hunyuan-MT-7B效果实测:Pixel Language Portal对中文网络用语、方言、谐音梗的跨维转码能力分析

Hunyuan-MT-7B效果实测:Pixel Language Portal对中文网络用语、方言、谐音梗的跨维转码能力分析 1. 引言:当翻译遇上像素冒险 在数字时代的语言交流中,传统翻译工具往往显得生硬而缺乏温度。Pixel Language Portal(像素语言跨维…...

突破性AMD Ryzen硬件调试方案:SMUDebugTool深度解析与实战指南

突破性AMD Ryzen硬件调试方案:SMUDebugTool深度解析与实战指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: ht…...

视频格式转换革新:m4s-converter让B站缓存视频无缝播放

视频格式转换革新:m4s-converter让B站缓存视频无缝播放 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 从缓存困境到自由播放&#x…...

电话号码定位开源工具实战完全指南:从部署到企业应用

电话号码定位开源工具实战完全指南:从部署到企业应用 【免费下载链接】location-to-phone-number This a project to search a location of a specified phone number, and locate the map to the phone number location. 项目地址: https://gitcode.com/gh_mirro…...

RTX 3090环境下的BEVFusion实战部署:从源码编译到多模态训练调优

1. RTX 3090环境准备与BEVFusion适配 在RTX 3090上部署BEVFusion最大的挑战就是硬件与软件版本的兼容性问题。官方推荐的环境是CUDA 9.2和PyTorch 1.3.1,但这对于RTX 3090来说完全不适用——30系显卡需要CUDA 11才能发挥全部性能。我刚开始尝试直接按照官方文档安装…...

如何高效解决网页视频下载难题:VideoDownloadHelper智能解析工具全解析

如何高效解决网页视频下载难题:VideoDownloadHelper智能解析工具全解析 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 在数字化内…...

2021必修 首门CSS架构系统精讲 理论+实战玩转蘑菇街 百度网盘

在前端开发的职场鄙视链里,存在一个极其普遍的误区:认为电商页面就是“简单的列表详情”,没什么技术含量。殊不知,电商是前端技术最残酷的练兵场:毫秒级的首屏速度、像素级的视觉还原、千人千面的动态布局、以及大促期…...

厦门选117E还是120E?手把手教你为你的城市选择正确的高斯克吕格投影坐标系

厦门GIS项目实战:如何精准选择高斯克吕格投影坐标系 第一次在ArcGIS里看到上百个坐标系选项时,我的鼠标指针在列表上方徘徊了整整十五分钟——就像站在自动售货机前不知道按哪个按钮的新手。特别是当项目 deadline 临近,而厦门市规划局的Shap…...

Linux网络命名空间实战:5分钟搞定veth pair跨命名空间通信

Linux网络命名空间实战:5分钟搭建隔离通信环境 在云计算和容器化技术蓬勃发展的今天,Linux网络命名空间已经成为系统管理员和开发者的必备技能。想象一下,当你需要在单台物理机上同时运行多个需要独立网络环境的服务时,传统方式可…...

轻量锐驰 x 轻量对象存储:构建个人专属高速云存储方案

1. 为什么你需要自建云存储? 每次用公共网盘传文件都像在参加龟速比赛?分享给朋友时对方总抱怨下载慢如蜗牛?我三年前就开始研究自建云存储方案,实测下来轻量锐驰服务器轻量对象存储的组合,速度能跑满家庭宽带上限&…...

S2-Pro数据库课程设计助手:从需求分析到SQL生成的全程辅助

S2-Pro数据库课程设计助手:从需求分析到SQL生成的全程辅助 1. 课程设计的痛点与解决方案 每到学期末,数据库课程设计就成了计算机专业学生的"必修课"。面对一个陌生的业务场景,从零开始梳理需求、设计E-R图、编写SQL语句&#xf…...

Intel XE核显PyTorch环境搭建避坑指南

1. 为什么选择Intel XE核显跑PyTorch? 最近很多小伙伴都在问,用Intel XE核显跑PyTorch到底靠不靠谱?作为一个在AI领域摸爬滚打多年的老司机,我可以很负责任地告诉你:完全可行!特别是对于预算有限的学生党&a…...

影墨·今颜模型API接口开发与调用全指南

影墨今颜模型API接口开发与调用全指南 你是不是已经成功部署了影墨今颜模型,看着它能在本地生成惊艳的图片,心里正盘算着怎么把它变成一个能对外服务的“产品”?比如,让公司的设计团队直接调用,或者集成到自己的应用里…...

卡证检测矫正模型中小企业降本:替代万元级专用证件扫描仪方案

卡证检测矫正模型:中小企业降本利器,替代万元级专用证件扫描仪方案 1. 引言:一个被忽视的降本痛点 如果你在中小企业负责行政、人事或财务,一定对下面这个场景不陌生:每天要处理一堆身份证、护照、驾照的复印件或扫描…...

Qwerty Learner字体优化:提升阅读体验的细节处理

Qwerty Learner字体优化:提升阅读体验的细节处理 【免费下载链接】qwerty-learner 为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers 项目地址: https://gitcode.…...

探索开源软件 FireGeo:地理空间数据处理的新选择

探索开源软件 FireGeo:地理空间数据处理的新选择 在地理空间数据处理的领域中,开源软件正以其独特的优势逐渐崭露头角,为众多专业人士和爱好者提供了丰富多样的工具。FireGeo 作为其中一款开源软件,正吸引着越来越多人的关注&…...

解锁JSON Viewer 3大效率黑科技:从数据解析到开发提效的全流程解决方案

解锁JSON Viewer 3大效率黑科技:从数据解析到开发提效的全流程解决方案 【免费下载链接】json-viewer It is a Chrome extension for printing JSON and JSONP. 项目地址: https://gitcode.com/gh_mirrors/js/json-viewer JSON Viewer是一款专为开发者打造的…...

PDF-Parser-1.0行业报告:市场分析与技术趋势

PDF-Parser-1.0行业报告:市场分析与技术趋势 1. 引言 每天都有成千上万份行业报告、白皮书和研究文档以PDF格式在企业间流转。这些文档蕴含着宝贵的市场洞察、技术趋势和商业机会,但手动提取和分析这些信息需要耗费大量时间和精力。PDF-Parser-1.0的出…...

HUNYUAN-MT 7B翻译终端Typora Markdown写作增强:实时双语文档创作

HUNYUAN-MT 7B翻译终端Typora Markdown写作增强:实时双语文档创作 1. 引言 如果你经常用Typora写技术博客或者项目文档,可能遇到过这样的场景:好不容易写完一篇内容详实的文章,想要分享给国际社区,却卡在了翻译上。手…...

Easypoi导出Excel时,如何优雅地处理‘未知’或‘空值’?一个replace动态替换的实战技巧

Easypoi动态替换Excel导出中的未知值与空值:实战技巧与最佳实践 在数据导出场景中,我们经常遇到数据库枚举值与Excel展示不匹配的问题。比如性别字段,除了标准的"男"、"女"外,还可能存在空值或超出预设范围的…...

Windows更新修复新范式:Reset-Windows-Update-Tool的系统化解决方案

Windows更新修复新范式:Reset-Windows-Update-Tool的系统化解决方案 【免费下载链接】Reset-Windows-Update-Tool Troubleshooting Tool with Windows Updates (Developed in Dev-C). 项目地址: https://gitcode.com/gh_mirrors/re/Reset-Windows-Update-Tool …...

EmbeddingGemma-300m效果展示:多语言文本相似度计算实战

EmbeddingGemma-300m效果展示:多语言文本相似度计算实战 1. 引言 文本嵌入模型正在改变我们处理多语言内容的方式。想象一下,你有一个包含中文、英文、法文等多种语言的文档库,如何快速找到语义相似的内容?传统的关键词匹配方法…...