Printf重定义

本文探讨了C语言中如何重定义`printf`函数,从编译器内置宏开始,详细介绍了常用和更高级的重定义方法,并讨论了优化`__FILE__`输出的策略。
摘要由CSDN通过智能技术生成

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
三、更高级的写法
/******************************************************************************
 * @Copyright (C), CVTE Electronics CO.Ltd 2021.
 * @File name: log.h
 * @Author: Gu Chunqi(guchunqi@cvte.com)
 * @Version: V1.0
 * @Date: 2021-05-14 11:18:30
 * @Description: LOG接口定义头文件
 * @Others: None
 * @History: <time>   <author>    <version >   <desc>
*******************************************************************************/

#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                     "
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32微控制器通常使用标准C库中的printf函数进行输出,但在一些情况下,可能需要定义或自定义printf函数的行为,特别是在嵌入式开发中,资源有限,或者需要特殊格式化输出时。在STM32中,你可能会遇到这样的需求,例如: 1. 串口通信:printf输出通常通过UART、USART或其他串行接口发送到外部设备,可能需要修改为直接通过硬件发送数据。 2. 缓存控制:为了节省内存,可以定义printf函数以缓存输出,仅在需要的时候再发送。 3. 扩展输出格式:自定义printf格式字符串以适应特定的应用需求。 在STM32中,你通常可以通过以下几个步骤来定义printf函数: - 包含头文件`stdio.h`,但不包含`stdarg.h`,因为该头文件包含了printf的声明,你需要自己实现。 - 定义一个函数,比如`my_printf`,原型应为`void my_printf(const char *format, ...)`,这遵循了printf函数的标准参数列表。 - 实现`my_printf`函数,根据`format`参数解析并处理输入的格式字符串和变量,然后选择适当的机制(如串口发送)将信息输出。 例如,下面是一个简单的示例: ```c #include "stm32f10x.h" // 或者其他STM32库 void my_printf(const char *format, ...) { va_list args; int i; va_start(args, format); // 初始化变量参数指针 while (*format) { // 遍历格式字符串 if (*format == '%') { // 当遇到格式说明符% char specifier = *(format + 1); // 读取下一个字符作为说明符 // 根据specifier处理不同的输出情况 // ... } else { // 字符不是说明符,简单复制到缓冲区 // ... } format++; // 移动到下一个字符 } // 输出缓冲区内容 // ... va_end(args); // 清理变量参数指针 } // 在你的代码中,用my_printf替换printf void main() { my_printf("Hello, world!\n"); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值