printf调试方案

方式1(繁琐)

#define _DEBUG

#ifdef   _DEBUG
printf("第一条调试信息");
#endif

#ifdef   _DEBUG
printf("第二条调试信息");
#endif

#ifdef   _DEBUG
printf("第三条调试信息");
#endif

每一条调试语句都需要使用两条宏定义来包围,这不但在代码的编写上不便,源码结构也不好看,工作量依然不小。
方式2(无法变参输出)

#define _DEBUG

#ifdef _DEBUG
#define DEBUG(info)  printf(info)
#else
#define DEBUG(info)
#endif

DEBUG("第一条调试信息");
DEBUG("第二条调试信息");
DEBUG("第三条调试信息");
DEBUG("第三条调试信息a=%d\n",a);//无法进行变参输出

方式3(解决以上两种问题)

C89标准中有几个标准宏定义:
LINE:在源代码中插入当前源代码行号;
FILE:在源文件中插入当前源文件名;
DATE:在源文件中插入当前的编译日期
TIME:在源文件中插入当前编译时间;
STDC:当要求程序严格遵循ANSI C标准时该标识被赋值为1;

#define DEBUG(format, …) printf (format, ##VA_ARGS)

DEBUG(“FILE: %s, LINE: %d…”,FILE,LINE,…)
__FILE__本身就会被编译器置换为字符常量,再进一步替换

DEBUG(“FILE:“FILE”, LINE: %d”,_LINE)
欲望是没有止境的,为什么每条语句都要写"FILE:“FILE”, LINE: %d "及__LINE这两个部分呢,这是不是太繁琐了?这是不是太繁琐了?这是不是太繁琐了?

#define DEBUG(format_ql,...)\ 
 printf("  FILE: "__FILE__"   LINE: %d: "format_ql"\n  ", __LINE__, ##__VA_ARGS__)

//调用方法与上相同,不同的是去掉了保留名__VA_ARGS__
#define DEBUG(fmt,arg...)          printf("FILE NAME:"__FILE__ "\r\n""LINE:%d\r\n"fmt"\r\n\n",__LINE__,##arg)


//注释掉调试信息
#define DEBUG(format_ql,...)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在你提供的引用中,可以看到你遇到了在使用printf函数时导致FreeRTOS卡死的问题。根据引用中的代码,print_usart2函数通过HAL_UART_Transmit函数将format格式化后的字符串发送到USART2串口上。其中,format是一个可变参数,通过vsprintf函数将参数格式化到buf缓冲区中。然后,通过HAL_UART_Transmit函数将buf中的内容发送出去。 根据引用中的描述,你尝试过使用printf.stdarg.c库,但是该库不支持float型的输出。因此,这可能解释了为什么在中断中使用float输出会导致程序卡住。 不过,根据引用中的描述,你还提到了一个新的发现,即可以使用sprintf函数来实现类似printf的功能。通过将得到的target字符串作为sprintf的输出,你可以将format格式化后的结果存储到target字符串中。这样,你可以将target字符串发送到USART2串口上,而不必使用printf函数。 因此,如果你想在FreeRTOS中使用printf函数而不卡死程序,你可以考虑以下几点: 1. 确保在使用printf函数前,先检查USART2串口的状态是否忙,如引用中的代码所示。 2. 如果你需要输出float型的数据,可以尝试使用sprintf函数将格式化后的结果存储到一个字符串中,然后发送该字符串到USART2串口上,如引用中的描述所示。 请注意,以上只是一些可能的解决方案,请根据具体的程序需求和硬件环境进行调试和优化。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [彻底解决FreeRTOS中的printf问题---写个伪printf](https://blog.csdn.net/weixin_54905089/article/details/128894088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Poetry _Distance

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值