其实是对于offsetof函数的灵活应用,关于offsetof函数:
#define offsetof(s, m) (size_t)&(((s *)0)->m)s是一个结构名,它有一个名为m的成员(s和m 是宏offsetof的形参,它实际是返回结构s的成员m的偏移地址.
(s *)0 是骗编译器说有一个指向类(或结构)s的指针,其地址值0
&((s *)0)->m 是要取得类s中成员变量m的地址. 因基址为0,这时m的地址当然就是m在s中的偏移
最后转换size_t 型,即unsigned int。
因此,我们可以根据成员地址来获取结构体变量,如下所示:
typedef struct mv_s mv_t;
struct mv_s {
mv_t *t;
char *name;
int age;
};
//something else
mv_t *mv, *mvt, *mvtt;
mv->t = ....;
mv->name = ...;
mv->age = ...;
mvtt = mv->t;
mvt = (mv_t *) ((u_char *) mvtt - offsetof(mv_t, t))
//now, mvt == mv
printf("%d\n", mvt->age);