帮忙看下这个带参的宏定义,看不懂?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了帮忙看下这个带参的宏定义,看不懂?相关的知识,希望对你有一定的参考价值。

#define assert_param(expr) ((void)0) 这句完全看不懂?

那么assert_param(IS_GPIO_ALL_PERIPH(GPIOx)); 会怎么替换?

参考技术A 具体的定义和用法在下面
void MY_NVIC_SetVectorTable(u32 NVIC_VectTab,u32 Offset)

assert_param(IS_NVIC_VECTTAB(NVIC_VectTab));
assert_param(IS_NVIC_OFFSET(Offset));
SCB->VTOR=NVIC_VectTab|(Offset&(u32)0x1FFFFF80);

这是断言机制。意思是在关闭断言的情况下,
void MY_NVIC_SetVectorTable(u32 NVIC_VectTab,u32 Offset)

assert_param(IS_NVIC_VECTTAB(NVIC_VectTab));
assert_param(IS_NVIC_OFFSET(Offset));
SCB->VTOR=NVIC_VectTab|(Offset&(u32)0x1FFFFF80);

就相当于:
void MY_NVIC_SetVectorTable(u32 NVIC_VectTab,u32 Offset)

(void)0; // 不执行任何操作,对程序也没有副作用
(void)0; // 不执行任何操作,对程序也没有副作用
SCB->VTOR=NVIC_VectTab|(Offset&(u32)0x1FFFFF80);

由于你的这个断言没贴完整,我就拿VC++6.0下的断言来说明把。
在VC++6.0下的assert.h中:
#ifdef NDEBUG
#define assert(exp) ((void)0)
#else
#define assert(exp) (void)( (exp) || (_assert(#exp, __FILE__, __LINE__), 0) )
如果你写的代码中使用了断言,比如:
assert(i>=0);
那么这句的在程序中的作用分两种情况:
1. 若果在assert.h被包含之前NDEBUG这个宏未定义,assert(exp) 就被定义为(void)( (exp) || (_assert(#exp, __FILE__, __LINE__), 0) )。这样当i<0时,i>=0这个表达式为假,所以程序就会终止。并通知程序员发生错误的文件位置和代码行。但是错误信息仅仅对程序员有用。对用户来说,程序异常终止就显得不是那么友好了(用户此时需要的是挽回错误)。所以在发布给用户的程序中,assert(断言)要关闭。在VC++6.0下这是通过在包含assert.h头文件之前定义NDEBUG实现的。
2.在定义了NDEBUG的情况下,断言不应该给程序带来副作用。这样断言就被定义为:
#define assert(exp) ((void)0)
此时,assert(i>=0);不管括号中表达式为真还是为假,这一行代码其实相当于:
NULL;意思是不执行任何操作。追问

额,,你好像理解错问题了,我问的是宏定义,和实际编译时的替换,你说成调试时才用到的断言了……而且我这个是C,不是C++……

以上是关于帮忙看下这个带参的宏定义,看不懂?的主要内容,如果未能解决你的问题,请参考以下文章

c语言宏定义有无参数的区别

宏定义与内联函数

宏定义的优缺点

C语言中的宏定义如何使用?

C语言中的宏定义有啥用?

我实在看不懂他这个颜色值是怎么表示的,话说是RGB(X,Y,Z) 谁能跟我说说 有图