標(biāo)題:
嵌入式c語(yǔ)言調(diào)試開(kāi)關(guān)
[打印本頁(yè)]
作者:
51黑黑黑
時(shí)間:
2016-2-22 23:07
標(biāo)題:
嵌入式c語(yǔ)言調(diào)試開(kāi)關(guān)
本帖最后由 51黑黑黑 于 2016-2-22 23:09 編輯
調(diào)試程序時(shí),經(jīng)常會(huì)用到assert和printf之類(lèi)的函數(shù),我最近做的這個(gè)工程里就有幾百個(gè)assert,在你自認(rèn)為程序已經(jīng)沒(méi)有bug的時(shí)候,就要除去這些調(diào)試代碼,應(yīng)為系統(tǒng)在正常運(yùn)行時(shí)這些用于調(diào)試的信息是無(wú)用的,而且會(huì)占用時(shí)間和空間。怎么刪除呢,俺以前都是用笨方法,一個(gè)一個(gè)注釋?zhuān)苡米⑨屢彩墙?jīng)過(guò)改進(jìn)的方法,俺最早都是刪掉之后出了問(wèn)題再重新寫(xiě)的,但是這次幾百個(gè)一個(gè)一個(gè)刪除的話(huà)可是要了俺的小命了,一首mp3聽(tīng)完,還不到一百個(gè)。以前看過(guò)st的函數(shù)庫(kù),老外的代碼就是規(guī)范,俺現(xiàn)在的代碼好多都是在st和ti那里照搬的,呵呵。
下面給出最簡(jiǎn)單的一種方法:
#define DEBUG
#ifdef DEBUG
#define PRINTF(x) printf x
#else
#define PRINTF(x) ((void)0)
#endif
復(fù)制代碼
使用時(shí),PRINTF(( "Hello World!\n\r" ));
注意這里是兩個(gè)括號(hào),一個(gè)會(huì)報(bào)錯(cuò)的
不使用時(shí),直接將"#define DEBUG"屏蔽掉
另外一個(gè)調(diào)試時(shí)常用的方法是assert,還是在一個(gè)頭文件里,這里用的是STM32函數(shù)庫(kù)的例子
#ifdef DEBUG 1
/*******************************************************************************
* Macro Name : assert_param
* Description : The assert_param macro is used for function's parameters check.
* It is used only if the library is compiled in DEBUG mode.
* Input : - expr: If expr is false, it calls assert_failed function
* which reports the name of the source file and the source
* line number of the call that failed.
* If expr is true, it returns no value.
* Return : None
*******************************************************************************/
#define assert_param(expr) ((expr) ? (void)0 : assert_failed((u8 *)__FILE__, __LINE__))
/* Exported functions ------------------------------------------------------- */
void assert_failed(u8* file, u32 line);
#else
#define assert_param(expr) ((void)0)
#endif/* DEBUG */
//assert_failed此函數(shù)要自己定義
#ifdef DEBUG
/*******************************************************************************
* Function Name : assert_failed
* Description : Reports the name of the source file and the source line number
* where the assert_param error has occurred.
* Input : - file: pointer to the source file name
* - line: assert_param error line source number
* Output : None
* Return : None
*******************************************************************************/
void assert_failed(u8* file, u32 line)
{
/* User can add his own implementation to report the file name and line number,
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
/* Infinite loop */
while (1){
}
}
#endif
復(fù)制代碼
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1