CRASH()宏–用法解释

2021年5月14日16:00:19 发表评论 1,111 次浏览

下面给出了一个开源项目中的一小段代码,

#ifndef __cplusplus
  
typedef enum BoolenTag
{
    false , true
} bool ;
  
#endif
  
#define CRASH() do { \
       (( void (*)())0)(); \
    } while ( false )
  
int main()
{
    CRASH();
    return 0;
}

你能解释上面的代码吗?

很简单, 下面给出逐步的方法,

该声明while(假)仅用于测试目的。考虑以下操作,

((void(*)())0)();

可以通过以下方式实现,

0;                      /* literal zero */
(0); ( ()0 );                /* 0 being casted to some type */
( (*) 0 );              /* 0 casted some pointer type */
( (*)() 0 );            /* 0 casted as pointer to some function */
( void (*)(void) 0 );   /* Interpret 0 as address of function 
 taking nothing and returning nothing */
( void (*)(void) 0 )(); /* Invoke the function */

因此, 给定的代码正在调用其代码存储在零位置的函数, 换句话说, 试图执行存储在零位置的指令。在具有内存保护(MMU)的系统上, 操作系统将引发异常(分段错误), 而在没有此类保护的系统(小型嵌入式系统)上, 操作系统将执行并且错误将进一步传播。

—文基。如果发现任何不正确的地方, 或者想分享有关上述主题的更多信息, 请写评论。

木子山

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: