container_of

  • Post author:
  • Post category:其他


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 版权协议,转载请附上原文出处链接和本声明。