Kshine0 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语言的巧妙,以及内核代码的构思,真真的灵活运用啊!