嵌入式C中的分级打印功能

	由于工作的需要,项目需要添加分级打印函数。分级打印函数的好处如下:
		1.产品在使用时,客户不想看到屏幕上有过多的打印信息,但是工作人员平时在调试的时候则需要通过打印信息定位问题。
		2.在调试过程中,可根据打印等级,显示问题的严重程度。
		
	打印等级一般有如下分类:
分类 描述
debug 一般用于程序开发测试时的打印输出,用于验证程序的设计逻辑是否满足上层应用的设计需求。
INFO 用来告诉测试人员或者开发人员一些特殊的信息。
WARN 这是一种警告的打印输出,它一般是用来输出诸如用户输入错误的数据之类的警告打印。
ERROR 运行出错的打印,一般用来表示程序运行异常,但是没有程序没有崩溃。
FATAL 这种出错的打印,一般用来表示程序运行崩溃。
	打印模块的实现代码如下:
#include 

/*打印等级*/
#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 
#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级别:

嵌入式C中的分级打印功能_第1张图片

	接下来,我们将打印模块代码中控制打印级别的宏定义 LOG_LEVEL 设为5,此时,五种类型都会打印:

嵌入式C中的分级打印功能_第2张图片

	至此,已经实现了嵌入式C中的分级打印功能,以上测试基于itop4412开发板,但是上述分级打印模块的功能与开发板无关,可随处移植。对于想要想要了解上述打印原理的小伙伴,请继续阅读:
接下来,再补充一个关于可变参数宏知识点:
C99中规定,宏可以像函数一样带有可变参数,比如
#define LOG(fmt, ...) fprintf(stdout, fmt, __VA_ARGS__)
其中,...表示参数可变,__VA_ARGS__在预处理中为实际的参数集所替换。

GCC中同时支持如下的形式
#define LOG(fmt, args...) fprintf(stdout, fmt, args)
其用法和上面的基本一致,只是参数符号有变化。

你可能感兴趣的:(C语言)