额,这个问题困扰我很长一段时间了...
- #define listGET_OWNER_OF_NEXT_ENTRY( pxTCB, pxList )
- {
- List_t * const pxConstList = ( pxList );
- /* Increment the index to the next item and return the item, ensuring */
- /* we don't return the marker used at the end of the list. */
- ( pxConstList )->pxIndex = ( pxConstList )->pxIndex->pxNext;
- if( ( void * ) ( pxConstList )->pxIndex == ( void * ) &( ( pxConstList )->xListEnd ) )
- {
- ( pxConstList )->pxIndex = ( pxConstList )->pxIndex->pxNext;
- }
- ( pxTCB ) = ( pxConstList )->pxIndex->pvOwner;
- }
复制代码
这是FreeRTOS的一段源码,小弟如果自己实现这段功能,我肯定(不加思索)使用函数.但既然源码使用宏(源码这样用,应该是有它的道理),小弟不明白,恳请指教...
问题1: 使用宏相比较函数有哪些优点和缺点?
问题2: (抛开个人习惯问题)在什么情况下应当使用函数,什么情况下应当使用宏?
个人理解使用函数的优点:
1> 会对参数类型进行检查,容易避免基本的语法错误...
2> 可能(至少对于我这种)会提高代码的可读性...
个人理解使用宏的优点:
1> 使用宏,实际上是代码替换,最直观的好处就是减少函数调用(不会额外增加堆栈深度)...
2> 宏的替换是在编译期间进行的,不会增加程序运行期间的负担...
红的好处比坏处大多了,要是有不同的实现方法,比如枚举、内联函数等等时,尽量不要使用宏。
在调试时,很显然宏是不友好的,而内联函数则可以进行调试。
遇到有重名的时候,宏就是一个灾难。要是程序代码多了,死都不知道怎么死的。
一周热门 更多>