由于工作的需要,项目需要添加分级打印函数。分级打印函数的好处如下:
1.产品在使用时,客户不想看到屏幕上有过多的打印信息,但是工作人员平时在调试的时候则需要通过打印信息定位问题。
2.在调试过程中,可根据打印等级,显示问题的严重程度。
打印等级一般有如下分类:
分类 | 描述 |
---|
debug | 一般用于程序开发测试时的打印输出,用于验证程序的设计逻辑是否满足上层应用的设计需求。 |
INFO | 用来告诉测试人员或者开发人员一些特殊的信息。 |
WARN | 这是一种警告的打印输出,它一般是用来输出诸如用户输入错误的数据之类的警告打印。 |
ERROR | 运行出错的打印,一般用来表示程序运行异常,但是没有程序没有崩溃。 |
FATAL | 这种出错的打印,一般用来表示程序运行崩溃。 |
打印模块的实现代码如下:
#include <stdio.h>
#define HI_LOG(levle, fmt...) \
do{ \
printf("[%s][%s]:[%s]:[%d]", levle, __FILE__, __FUNCTION__, __LINE__); \
printf(fmt); \
printf("\n"); \
}while(0)
#define LOG_LEVEL 0
#if(LOG_LEVEL == 0)
#define HI_LOG_FATAL(fmt...)
#define HI_LOG_ERROR(fmt...)
#define HI_LOG_WARN(fmt...)
#define HI_LOG_INFO(fmt...)
#define HI_LOG_DEBUG(fmt...)
#elif(LOG_LEVEL == 1)
#define HI_LOG_FATAL(fmt...) HI_LOG("FATAL", fmt)
#define HI_LOG_ERROR(fmt...)
#define HI_LOG_WARN(fmt...)
#define HI_LOG_INFO(fmt...)
#define HI_LOG_DEBUG(fmt...)
#elif(LOG_LEVEL == 2)
#define HI_LOG_FATAL(fmt...) HI_LOG("FATAL", fmt)
#define HI_LOG_ERROR(fmt...) HI_LOG("ERROR", fmt)
#define HI_LOG_WARN(fmt...)
#define HI_LOG_INFO(fmt...)
#define HI_LOG_DEBUG(fmt...)
#elif(LOG_LEVEL == 3)
#define HI_LOG_FATAL(fmt...) HI_LOG("FATAL", fmt)
#define HI_LOG_ERROR(fmt...) HI_LOG("ERROR", fmt)
#define HI_LOG_WARN(fmt...) HI_LOG("WARN", fmt)
#define HI_LOG_INFO(fmt...)
#define HI_LOG_DEBUG(fmt...)
#elif(LOG_LEVEL == 4)
#define HI_LOG_FATAL(fmt...) HI_LOG("FATAL", fmt)
#define HI_LOG_ERROR(fmt...) HI_LOG("ERROR", fmt)
#define HI_LOG_WARN(fmt...) HI_LOG("WARN", fmt)
#define HI_LOG_INFO(fmt...) HI_LOG("INFO", fmt)
#define HI_LOG_DEBUG(fmt...)
#elif(LOG_LEVEL == 5)
#define HI_LOG_FATAL(fmt...) HI_LOG("FATAL", fmt)
#define HI_LOG_ERROR(fmt...) HI_LOG("ERROR", fmt)
#define HI_LOG_WARN(fmt...) HI_LOG("WARN", fmt)
#define HI_LOG_INFO(fmt...) HI_LOG("INFO", fmt)
#define HI_LOG_DEBUG(fmt...) HI_LOG("DEBUG", fmt)
#endif
测试的主函数如下:
#include <stdio.h>
#include "common.h"
int main()
{
int a = 3, b = 4, c = 5, d= 6, e = 7;
HI_LOG_FATAL("a = %d", a);
HI_LOG_ERROR("b = %d", b);
HI_LOG_WARN("c = %d", c);
HI_LOG_INFO("d = %d", d);
HI_LOG_DEBUG("e = %d", e);
return 0;
}
运行代码开始测试:
首先,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为0,此时,不会有任何打印:
接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为1,此时,只打印fatal级别:
接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为2,此时,只打印fatal和error级别:
接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为3,此时,只打印fatal,error和warn级别:
接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为4,此时,只打印fatal,error,warn和info级别:
接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为5,此时,五种类型都会打印:
至此,已经实现了嵌入式C中的分级打印功能,以上测试基于itop4412开发板,但是上述分级打印模块的功能与开发板无关,可随处移植。对于想要想要了解上述打印原理的小伙伴,请继续阅读:
接下来,再补充一个关于可变参数宏知识点:
C99中规定,宏可以像函数一样带有可变参数,比如
#define LOG(fmt, ...) fprintf(stdout, fmt, __VA_ARGS__)
其中,...表示参数可变,__VA_ARGS__在预处理中为实际的参数集所替换。
GCC中同时支持如下的形式
#define LOG(fmt, args...) fprintf(stdout, fmt, args)
其用法和上面的基本一致,只是参数符号有变化。