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

查看:204
本文介绍了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)是啥意思,为什么要这样写

解决方案

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

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

这篇关于C语言关于结构体的指针问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆