C语言关于结构体的指针问题

在看别人的C代码时碰到了这样一句

#ifndef offsetof
#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
#endif

#define container_of(ptr, type, member) \
    ((type *) ((char *) (ptr) - offsetof(type, member)))

struct test {
    struct hash_node node;
    int i, j;
};

有这么一句调用:

static int cmp_test(struct hash_node *node, void *key) {
    struct test *t = container_of(node, struct test, node);
    int *i = key;
    return t->i == *i;
}

我把container_of宏替换之后是这样的:
((struct test *) ((char *) (node) - ((size_t) &((struct test *)0)->node)))
offsetof(TYPE, MEMBER)宏替换后是这样的:
((size_t) &((struct test *)0)->node)
请问下((size_t) &((struct test *)0)->node)是啥意思,为什么要这样写

阅读 3.4k
1 个回答

怎么获取结构体内成员在结构体内的偏移?
答案: 结构体成员内存地址 - 结构体的起始内存地址。
这里还要涉及两个取地址操作和一个减操作。

有没有更好的方案呢?
有,把结构体放在内存0地址起始,然后直接取成员地址是不是就是其偏移了。
// 这里并不需要真正的放,只需要把0地址开始的一段《视为》结构体就行了,这就是对0进行类型转换。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进