log信息打印接口函数

本文介绍了__VA_ARGS__在格式化输出函数printf中的作用,特别是在需要重定向输出到串口的情况。同时,讨论了是否保存日志到文件的不同需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

##__VA_ARGS__的作用,printf函数在格式化输出时,需要重定向char putchar(char c);改成串口输出

/* stm32f103 寄存器操作 重定向putchar */
char putchar(char ch)
{
	while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
    USART1->DR = (u8) ch;      
	return c;
}

不需要将log保存在日志文件中

#define LOG_ERROR(fmt, ...) printf("[ERROR] <%s()>%d"fmt"\n", __func__, __LINE__, ##__VA_ARGS__)
#define LOG_WARN(fmt, ...) printf("[WARN] <%s()>%d"fmt"\n", __func__, __LINE__, ##__VA_ARGS__)
#define LOG_INFO(fmt, ...) printf("[INFO] <%s()>%d"fmt"\n", __func__, __LINE__, ##__VA_ARGS__)
#define LOG_DEBUG(fmt, ...) printf("[DEBUG] <%s()>%d"fmt"\n", __func__, __LINE__, ##__VA_ARGS__)

需要将log保存在日志文件中

#ifndef __DEBUG_H_
#define __DEBUG_H_

typedef enum {
  LOG_ERROR,
  LOG_WARN,
  LOG_INFO,
  LOG_DEBUG,
  LOG_MAX,
} LogLevel;

#define PRINT_LEVEL     LOG_MAX    /* 默认调试级别 */
#define NameLevel(name) (#name)      

int LogPrint(LogLevel level, const char *fmt, ...);
#define M_LOG(level, fmt, ...) \
do { \
    LogPrint(level, "<%s() ln:%d> " fmt "\r\n",  __FUNCTION__, __LINE__, ##__VA_ARGS__); \
} while (0)
#define M_LOG_ERROR(fmt, ...) M_LOG(LOG_ERROR, fmt, ##__VA_ARGS__)
#define M_LOG_WARN(fmt, ...) M_LOG(LOG_WARN, fmt, ##__VA_ARGS__)
#define M_LOG_INFO(fmt, ...) M_LOG(LOG_INFO, fmt, ##__VA_ARGS__)
#define M_LOG_DEBUG(fmt, ...) M_LOG(LOG_DEBUG, fmt, ##__VA_ARGS__)

#endif // !__DEBUG_H_
#include "debug.h"

#include <stdio.h>
#include <stdarg.h>

const char *g_levelInfo[LOG_MAX] = {
	[LOG_ERROR] = "ERROR",
	[LOG_WARN] = "WARN",
	[LOG_INFO] = "INFO",
	[LOG_DEBUG] = "DEBUG",
};
/* 这个通常用于将log保存在日志文件中,可以通过snprintf函数从格式化参数中获取数据 */
int LogPrint(LogLevel level, const char* fmt, ...)
{
	va_list valist;

	if ((level > LOG_MAX) || (level < LOG_ERROR) || (fmt== NULL)) {
		printf("[LOG_IGNORE]: log input para invaild\n");
		return -1;
	}
	if (level > PRINT_LEVEL) {
		return 0;
	}
	va_start(valist, fmt);
	printf("[%s] ", g_levelInfo[level]);
	vprintf(fmt, valist);
	va_end(valist);

	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值