Printf重定义
一、编译器内置宏
ANSI C标准中有几个标准预定义宏(也是常用的):
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus:当编写C++程序时该标识符被定义。
二、常用Printf重定义的几种写法
#if __LOG__
#define LOG(format,...) printf("[DATE]:%s, [FILE]:%s, [FUNC]:%s, [LINE]:%04d:"format"\r\n", __DATE__, __FILE__, __func__, __LINE__, ##__VA_ARGS__)
#else
#define LOG(format,...) do {
} while (0)
#endif
三、更高级的写法
#ifndef __LOG_H__
#define __LOG_H__
#include "common_def.h"
#include <stdio.h>
#if __LOG_EN__
#define COLOR_END "\033[0m"
#define INFO_COLOR "\033[36m"
#define DEBUG_COLOR "\033[35m"
#define DEBUG_ARRAY_COLOR "\033[35m"
#define WARNING_COLOR "\033[33m"
#define ERROR_COLOR "