本帖最后由 51黑黑黑 于 2016-2-22 23:09 編輯
調(diào)試程序時,經(jīng)常會用到assert和printf之類的函數(shù),我最近做的這個工程里就有幾百個assert,在你自認為程序已經(jīng)沒有bug的時候,就要除去這些調(diào)試代碼,應(yīng)為系統(tǒng)在正常運行時這些用于調(diào)試的信息是無用的,而且會占用時間和空間。怎么刪除呢,俺以前都是用笨方法,一個一個注釋,能用注釋也是經(jīng)過改進的方法,俺最早都是刪掉之后出了問題再重新寫的,但是這次幾百個一個一個刪除的話可是要了俺的小命了,一首mp3聽完,還不到一百個。以前看過st的函數(shù)庫,老外的代碼就是規(guī)范,俺現(xiàn)在的代碼好多都是在st和ti那里照搬的,呵呵。
下面給出最簡單的一種方法:
- #define DEBUG
- #ifdef DEBUG
- #define PRINTF(x) printf x
- #else
- #define PRINTF(x) ((void)0)
- #endif
復(fù)制代碼 使用時,PRINTF(( "Hello World!\n\r" ));
注意這里是兩個括號,一個會報錯的
不使用時,直接將"#define DEBUG"屏蔽掉
另外一個調(diào)試時常用的方法是assert,還是在一個頭文件里,這里用的是STM32函數(shù)庫的例子
- #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ù)制代碼
|