linux 内核代码的offsetof()宏
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语言的巧妙,以及内核代码的构思,真真的灵活运用啊!
相关推荐
  Kshine0    2015-07-09  
   dfBeautifulLive    2019-10-26  
   GUAOSHITAIDU    2018-01-19  
   forrestou    2019-09-05  
   jiaomrswang    2019-06-29  
   ElementW    2018-01-19  
   我只是个程序员    2015-06-29  
   沉着前进    2014-07-21  
   forrestou    2019-06-25  
   哈嘿Blog    2016-09-08  
   zzpdljd    2016-05-05  
   fkuevip    2016-04-05  
   前端档案    2015-04-14  
   PHP100    2019-03-27  
   BitTigerio    2018-01-31  
   编程爱好者联盟    2017-02-08  
 