linux 内核代码的offsetof()宏

doITwhat 2015-07-09

http://blog.csdn.net/mndscc/article/details/46803917

* 之前一直不理解((type *)0->member)是啥意思;甚至之前还在测试这种用法是否正确。
 * 这次在看list_entry的时候,又发现了这个用法。
 * 是在offsetof(type,member)中被调用的,
 * 原宏为:
#define offsetof(type,member) ((size_t) &((type *)0)->member)
 * size_t 是内核中的一种数据类型。是无符号的长整形。
 * 这个宏的作用是,计算元素member在其所在结构提type中的偏移量。
 * 那 看代码,还是不理解 。这不是在取member的地址么,还强制转化成size_t类型,
 * 怎么就是他在里面的偏移量了呢?甚至,用0->取元素,这种用法对还是错呢?
 * 哈哈,其实,重点就在用0->取元素上。
 *
 * 我们知道,定义结构体,内存会分配一块连续内存。结构体变量名也是该块连续内存的首地址。
 * 平时取元素 ,也是利用偏移量来进行操作。
 * 结构体内某一个元素的地址  =  结构体变量地址(即首地址)+ 偏移量。
 * 所以,如果结构体变量地址 == 0;
 * 该元素的地址 == 偏移量。
 * 所以,利用这样的小技巧,通过从0(NULL)作为首地址取元素,
 * 只要获取该元素的地址,就是该元素在其结构体内的偏移量了。

真的感叹c语言的巧妙,以及内核代码的构思,真真的灵活运用啊!

相关推荐