http://blog.chinaunix.net/uid-23069658-id-4745433.html
这篇文章对container_of讲的很清楚,感谢博主。
一、对container_of函数理解
我只是结合TCP/IP中container_of的使用,记录一下自己的理解。
#define container_of(ptr, type, member) ({ \
const typeof( ((type *)0)->member ) *__mptr = (ptr); \
(type *)( (char *)__mptr - offsetof(type,member) );})
#define offsetof(TYPE, MEMBER) ((size_t)&((TYPE *)0)->MEMBER)
一个首地址位于0的结构中member成员的地址,即为该member成员相对于该结构体首地址的偏移。如下图所示:
二、container_of函数总结
因此,整个container_of函数是用于计算出一个结构实际的地址。
从
container_of
(
ptr
,
type
,
member
)
函数中可以看出,第一个参数主要用于确定member位置,后两个参数用于计算offsetof。
三、container_of函数在TCP/IP中
for(pos = hlist_entry_safe((head)->first, typeof(*(pos)), member);\
pos; \
pos = hlist_entry_safe((pos)->member.next, typeof(*(pos)), member))
hlist_entry_safe函数主要使用了container_of
在不断取得下一个结构体地址时,只有container_of的第一个参数进行指针后移便可。
即:
for (pos = container_of((head)->first, typeof(*(pos)), member);\
pos; \
pos = container_of((pos)->member.next, typeof(*(pos)), member))
第一个参数后移,即可完成for循环
版权声明:本文为maryfei原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。