kenlistian

厚积薄发. 勤为桨,思为帆

   :: 首页 :: 新随笔 ::  :: 聚合  :: 管理 ::
  73 随笔 :: 4 文章 :: 22 评论 :: 0 Trackbacks


关于偏移量的宏定义

#define offsetof(s,m)   (size_t)&(((s *)0)->m)

s是一个结构名,它有一个名为m的成员(s和m 是宏offsetof的形参,
它实际是返回结构s的成员m的偏移地址


(s *)0 是骗编译器说有一个指向类(或结构)s的指针,其地址值0 

&((s *)0)->m   是要取得类s中成员变量m的地址 
          因基址为0,这时m的地址当然就是m在s中的偏移

最后转换size_t 型,即unsigned int。

有例子如: 
  struct   AAA 
  { 
    int   i; 
    int   j; 
  }; 
  
  struct   AAA   *pAAA; 
  pAAA = new   AAA; 
  这时,pAAA实际上是一个Pointer, 指向某一确定的内存地址,
     如0x1234; 
  而pAAA->i 整体是一个int型变量,其地址是&(pAAA->i),
  '&'为取址运算符; 
  那么&(pAAA->i)一定等于0x1234,因 i 是结构体AAA的第一个元素。 
  而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因为sizeof(int) = 4; 
  
  这个做法的巧妙之处就是:它把“0”作为上例中的pAAA,那么&(pAAA->j)就是j的 
  offset啦, 

  解析结果是: 
  (s*)0,将 0 强制转换为Pointer to "s"   
  可以记 pS = (s*)0,pS是指向s的指针,它的值是0; 
  那么pS->m就是m这个元素了,而&(pS->m)就是m的地址,
  就是offset啦    




posted on 2008-10-27 17:16 kenlistian 阅读(661) 评论(0)  编辑 收藏 引用 所属分类: cpp

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理