當(dāng)前位置:
首頁 >
用宏定义代替printf函数
發(fā)布時(shí)間:2025/6/15
33
豆豆
生活随笔
收集整理的這篇文章主要介紹了
用宏定义代替printf函数
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
問題提出
有時(shí)候我們想用宏定義來決定是編譯debug版本的代碼還是release的代碼,dubug版本的代碼會(huì)通過printf打印調(diào)試信息,release版本的代碼則不會(huì)。我們總不能對(duì)每一條printf都這樣寫:
#if _DEBUG_ printf("hello world!"); #endif這樣子實(shí)在是太麻煩了!萬一要各個(gè)地方都要打印,會(huì)使版面看起來很亂。
解決方法
我后來想到一個(gè)方法,可以使用宏定義代替printf函數(shù),由于printf是可變參數(shù)的函數(shù),這里就要用到變參宏(…和__VA_ARGS__)。?
在頭文件下寫此代碼
后面需要打印調(diào)試信息的時(shí)候使用PR宏就可以了,如果需要release版本,不打印調(diào)試信息,就把DEBUG設(shè)置為0,編譯出來的程序就不會(huì)打印調(diào)試信息了。
示例代碼清單
開發(fā)環(huán)境VS2013。當(dāng)DEBUG設(shè)置為1,打印PR的信息;當(dāng)DEBUG設(shè)置為0,不打印PR的信息。
#include "stdafx.h"#define _DEBUG_ 1#if _DEBUG_ #define PR(...) printf(__VA_ARGS__) #else #define PR(...) #endifint _tmain(int argc, _TCHAR* argv[]) {printf("debug test!\r\n");PR("hello world!\r\n");PR("string:%s\r\n", "data");PR("integer:%d\r\n", 100);return 0; }提醒
該技巧可以用在單片機(jī)C語言開發(fā)上,切換版本非常方便。
總結(jié)
以上是生活随笔為你收集整理的用宏定义代替printf函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: STM32中stm32f0xx_flas
- 下一篇: stm32f10x_it.c 定义的程序