container_of
宏是一个用于获取结构体实例的指针,通过其成员变量的指针
在 C 语言中,结构体的内存布局是连续的。这意味着结构体中的成员变量在内存中是按照它们在结构体定义中的顺序排列的。因此,我们可以通过成员变量的地址来计算出结构体实例的地址。
container_of
宏的实现原理如下:
- 首先,获取成员变量指针
ptr
的类型大小(sizeof(*ptr)
)。 - 然后,计算成员变量在结构体中的偏移量。这可以通过将成员变量的地址减去结构体实例的地址来实现。
- 最后,将成员变量的地址减去其在结构体中的偏移量,得到结构体实例的地址。
举个例子,假设我们有以下结构体定义:
struct foo { int a; int b; };
现在,我们有一个指向 b
成员变量的指针 int *ptr
,我们可以使用 container_of
宏来获取指向结构体实例的指针:
struct foo *instance = container_of(ptr, struct foo, b);
这里,container_of
宏会计算出 b
成员变量在结构体 foo
中的偏移量,然后将 ptr
的地址减去该偏移量,从而得到结构体实例的地址。
总之,container_of
宏与内存布局之间的关系是通过计算成员变量在结构体中的偏移量来获取结构体实例的指针。这要求结构体的内存布局是连续的,这在 C 语言中是成立的。