C语言代码经常要进行出错处理。调用assert,系统自带的assert输出统一。所以我们需要自己分装一个assert,来输出更多我们自己想要的信息
#include <stdio.h>
//#undef _EXAM_ASSERT_TEST_ //禁用
#define _EXAM_ASSERT_TEST_ //启用
#ifdef _EXAM_ASSERT_TEST_ //启用断言测试
void assert_report( const char * file_name, const char * function_name, unsigned int line_no )
{
printf( "\n[EXAM]Error Report file_name: %s, function_name: %s, line %u\n",
file_name, function_name, line_no );
abort();
}
#define ASSERT_REPORT( condition ) \
do{ \
if ( condition ) \
NULL; \
else \
assert_report( __FILE__, __func__, __LINE__ ); \
}while(0)
#else // 禁用断言测试
#define ASSERT_REPORT( condition ) NULL
#endif /* end of ASSERT */
do{}while(0);语句可以有效的防止ASSERT_REPORT宏对于调用着本身的逻辑结构产生影响。如下面的代码
#ifdef _EXAM_ASSERT_TEST_ //启用断言测试
void assert_report( const char * file_name, const char * function_name, unsigned int line_no )
{
printf( "\n[EXAM]Error Report file_name: %s, function_name: %s, line %u\n",
file_name, function_name, line_no );
abort();
}
#define ASSERT_REPORT( condition ) \
if ( condition ) \
NULL; \
else \
assert_report( __FILE__, __func__, __LINE__ );
#else // 禁用断言测试
#define ASSERT_REPORT( condition ) NULL
#endif /* end of ASSERT */
#define printf_define()\
printf("one line!\n");\
printf("two line!\n");
int main(int argc, char *argv[])
{
int i = 0;
if(1 == i)
printf_define();
|
拆开宏带入
|
if(1 == i)
printf("one line!\n");
printf("two line!\n");
}
看出了什么问题吗?ASSERT_REPORT的带入,本身的逻辑结构就呗破坏了。只能执行到printf("two line!\n");
,di{}while(0);可以保证一段代码被完整的执行到。
参考大佬们的经验