#define offsetof(type,member) (size_t)&(((type*)0)->member)
在这里我们解释一下这个宏定义, 0我们知道 和NULL 一样的意思 但是为什莫上面的表达式可以运行, 我们知道操作一个空指针不是会segment fault 吗?
这里就要解释一下了 这个宏 并不是时我们想的那样, 因为宏是在 编译时处理的 而指针的引用实在运行时 用的, 所以这个写法没问题。
(size_t)&(((type*)0)->member) 这里要归功与& 取地址 运算的功劳,他表示去一个地址,所以整个表达式就是 取后边的变量的地址,在编译时就有花了 所以根本不会在运行时 去真是的运行。所以不会错。
而0就表示内存的其实地址也即是0x00000000 地址。