#define offsetof(s, m) (size_t)&(((s*)0)->m)
注意:"&"这里是取地址符的意思,而不是位运算的与,害的我郁闷了很长时间。。
说到底,一种欺骗战术。
offsetof 求某个结构体的特定成员在结构体里面的偏移量
(s *)0 是骗编译器说有一个指向类(或结构)s的指针,其值为0
&((s *)0)->m 是要取得类s中成员变量m的地址
由于这个类(或结构)的基址为0,这时m的地址当然就是m在s中的偏移了
(s *)0 是把0地址转换为s指针类型,然后从这个指针上“取”m成员再取址,而m成员的地址转换后结果就是m成员相对于整个对象的偏移量(我们既然是从0地址开始算的,就不用再减去起始地址0)。