嵌入式日志输出

  嵌入式开发进行调试或者查找BUG时,常见的两种方法是仿真和日志打印的。但是在编写嵌入式软件程序过程时,并不是所有的硬件都支持仿真或者方便仿真,所以大多数方法是加打印信息来进行查找问题的。打印的接口有很多种,比如串口,网络,显示等等。这里简单记录下日志打印方法。

一、日志打印的目的

  1)方便查找打印日志
  2)日志格式规范
  3)可以查看用户添加信息,文件信息,函数接口,以及文件所在行号
  4)支持format格式
  5)可以支持实时时间

二、日志打印的基本知识

  C语言中的__FILE__、LINE__和 __FUNCTION
  1、FILE 用于指示本行代码所在源文件的文件名;
  2、__LINE__用于指示本行代码所在源文件中的位置(行数);
  3、__FUNCTION__用于指示本行代码所在函数(函数名);
注:
  1)"FILE "、“LINE”、"FUNCTION"等均大小写敏感
  2)支持需要添加头文件#include<stdio.h>

三、源码

#define DEBUG_EN (1u)
 
#if (DEBUG_EN)
 
#define DEBUG_MAX_SIZE 512
extern char szBuf[DEBUG_MAX_SIZE];
 
#define DEBUG_INFO( format, ... ) do{\
    u16 unLen = 0;\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[INFO][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );\
    usart1_send_buf_with_txe((u8 *)szBuf,unLen);\
}while(0)
 
#define DEBUG_WARN( format, ... ) do{\
    u16 unLen = 0;\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[WARN][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );\
    usart1_send_buf_with_txe((u8 *)szBuf,unLen);\
}while(0)
 
#define DEBUG_ERR( format, ... ) do{\
    u16 unLen = 0;\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[ERR][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);\
    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );\
    usart1_send_buf_with_txe((u8 *)szBuf,unLen);\
}while(0)
 
#elif 
 
#define DEBUG_INFO(...)
#define DEBUG_WARN(...)
#define DEBUG_ERR(...)
 
#endif

  源码主要使用宏定义的方式,为了支持文件、行号,函数等等,不能使用单独的函数进行定义。C文件目前只有一个数组定义char szBuf[DEBUG_MAX_SIZE]。为了兼容,INFO,WARN和ERR三个共用一个buf,声明全局变量更主要的一个原因是使用了串口的中断发送函数usart1_send_buf_with_txe,而不是循环发送完成再退出,这里传输是进行指针传递的,发送使用中断的好处就是高效率,不耽误其他程序跑。当然移植的时候完全可以根据自己的接口和实现方式进行更换。

四、打印log的原则

  1、异常分支或错误处理一定要打log
  2、重大操作时一定要打log,

五、log格式的原则

  1、时间戳必须有,最好能够精确到微秒。
  一般格式:

[20170109 121630.541]

  2、打log位置的文件名和代码行数。这个不用说,用于定位问题根源。
  一般格式:

[20170109 121630.541][network.c:541]

  3、有进程id。
  一般格式:

[20170109 121630.541][network.c:541][pid=15529]

  4、有线程id。在多线程程序,如果不加线程id,很难追溯程序的行为
  一般格式:

[20170109 121630.541][network.c:541][pid=15529][thread=0x12345]

  5、有日志的级别。日志是反映问题的,有不同紧急程序的问题,自然有不同的日志级别。一般采用Error,Warning,Info,Debug。定义不同级别,也可以方便在日志查找问题来源。
  一般格式:

[20170109 121630.541][network.c:541][pid=15529][thread=0x12345][Error]
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 嵌入式Qt开发项目教程目录通常包括以下几个主要部分: 1. 嵌入式Qt开发入门:介绍嵌入式Qt开发的基础知识和环境准备,包括Qt的安装和配置,嵌入式开发板的选择和搭建等。 2. Qt编程基础:介绍Qt的基本编程概念和常用类库,包括信号与槽机制、界面设计、布局管理器、事件处理等内容。 3. Qt多媒体应用开发:介绍如何使用Qt开发多媒体应用,包括音频播放、视频播放、图像处理等相关内容。 4. Qt网络应用开发:介绍如何使用Qt进行网络通信,包括TCP/IP通信、UDP通信、HTTP通信等相关内容。 5. Qt数据存储和数据库:介绍如何使用Qt进行数据存储和数据库操作,包括文件读、XML处理、SQLite数据库等相关内容。 6. 嵌入式Qt界面开发:介绍如何使用Qt进行界面开发,包括窗口管理、界面布局、控件使用、多语言支持等相关内容。 7. Qt图形应用开发:介绍如何使用Qt进行图形应用开发,包括图形绘制、图像处理、动画效果等相关内容。 8. 嵌入式Qt性能优化:介绍如何对嵌入式Qt应用进行性能优化,包括代码优化、内存管理、资源优化等相关内容。 9. 嵌入式Qt应用部署:介绍如何将嵌入式Qt应用部署到目标设备上,包括交叉编译、打包发布、调试技巧等相关内容。 总的来说,嵌入式Qt开发项目教程目录应该涵盖了从入门到实践的全面内容,帮助读者掌握嵌入式Qt开发的基本知识和技能,并能够独立完成嵌入式Qt应用的开发和部署。 ### 回答2: 嵌入式Qt开发项目教程目录如下: 第一章:嵌入式Qt开发介绍 - 介绍嵌入式Qt开发的概念和应用场景。 - 介绍Qt平台及其特点。 第二章:环境搭建 - 介绍嵌入式开发平台,如Linux或RTOS。 - 介绍Qt开发环境的安装和配置。 - 介绍交叉编译工具链的搭建。 第三章:Qt基础知识 - 介绍Qt的基本概念,如信号和槽机制、对象树等。 - 介绍Qt常用的核心类,如QWidget、QLabel、QPushButton等。 - 讲解Qt的布局管理器和UI设计工具。 第四章:嵌入式Qt应用开发 - 介绍Qt的事件处理和多线程编程。 - 讲解Qt的网络通信和数据库访问。 - 介绍Qt图形和动画的应用。 第五章:嵌入式Qt与硬件交互 - 介绍如何使用Qt与硬件进行交互,如GPIO、串口、I2C等。 - 讲解Qt的音频和视频处理能力。 第六章:嵌入式Qt应用优化和调试 - 介绍Qt应用的性能优化技巧。 - 讲解如何使用Qt Creator进行调试和单元测试。 - 介绍Qt的错误处理和日志记录。 第七章:嵌入式Qt应用部署与发布 - 介绍Qt应用的打包和部署策略。 - 讲解如何进行Qt应用的远程调试和更新。 第八章:案例分析与实践 - 通过实际的嵌入式Qt开发案例,加深对前述知识点的理解。 - 讨论如何解决实际项目中遇到的问题。 此目录提供了一条完整的嵌入式Qt开发学习路径,从环境搭建到高级应用优化,逐步引导读者了解嵌入式Qt开发的各个方面,并附带示例代码和实践案例,帮助读者更好地理解和掌握该领域的知识与技能。 ### 回答3: 嵌入式Qt开发项目教程目录可以大致分为以下几个部分: 1. Qt简介: - Qt介绍 - Qt的优点和特点 - Qt的应用领域 - Qt的版本和许可 2. 嵌入式Qt开发环境设置: - 操作系统的选择和配置 - Qt SDK的安装 - Qt Creator的配置 - SDK的交叉编译配置 - Qt交叉编译工具链的配置 3. 基本Qt开发知识: - Qt的核心概念和类库 - Qt的信号与槽机制 - Qt的事件处理 - Qt的界面设计和布局 4. 嵌入式应用程序架构设计: - 嵌入式应用程序的特点和要求 - 设计模式在嵌入式Qt开发中的应用 - MVC模式和Qt的数据模型 - 多线程编程 5. 嵌入式Qt开发工具的使用: - Qt Creator的使用技巧 - 调试嵌入式Qt应用程序 - 嵌入式Qt应用程序的性能优化 - Qt的国际化和本地化支持 6. 嵌入式Qt常用模块的使用: - Qt网络编程 - Qt数据库编程 - Qt图形编程 - Qt多媒体编程 - Qt传感器编程 - Qt系统操作和硬件控制 7. Qt在嵌入式系统中的应用案例: - 嵌入式Qt应用的开发流程 - 嵌入式Qt应用的实际项目案例 - Qt在物联网和智能家居中的应用 通过以上这些章节和具体内容,可以帮助初学者系统地了解嵌入式Qt开发的基本知识和技能,并能够应用于实际项目中。当然,根据实际情况,可以根据项目需求进行适当的调整和补充。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值