offsetof 宏定义的详解

#define offsetof(type,member) (size_t)&(((type*)0)->member) 

 在这里我们解释一下这个宏定义, 0我们知道 和NULL 一样的意思 但是为什莫上面的表达式可以运行, 我们知道操作一个空指针不是会segment fault 吗? 

这里就要解释一下了 这个宏 并不是时我们想的那样, 因为宏是在 编译时处理的 而指针的引用实在运行时 用的, 所以这个写法没问题。

(size_t)&(((type*)0)->member)  这里要归功与& 取地址 运算的功劳,他表示去一个地址,所以整个表达式就是 取后边的变量的地址,在编译时就有花了 所以根本不会在运行时 去真是的运行。所以不会错。

而0就表示内存的其实地址也即是0x00000000 地址。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章