offsetof 函数解析 .
1 offsetof(s,m)解析 offsetof(s,m)解析
offsetof(s,m)解析 offsetof(s,m)解析
 2 
 
 3 今天看代码时,发现一个有用的东东,offsetof(s,m),这是一个宏,定义如下:
今天看代码时,发现一个有用的东东,offsetof(s,m),这是一个宏,定义如下:
 4
 5 #define offsetof(s,m) (size_t)&(((s *)0)->m)
 #define offsetof(s,m) (size_t)&(((s *)0)->m)
 6 
 
 7 然后到网上查了一下,发现还真的是很有用,附带一位大侠的解说:
 然后到网上查了一下,发现还真的是很有用,附带一位大侠的解说:
 8
 9 struct   AAA
  struct   AAA   
10 {
  {   
11 int   i;
  int   i;   
12 int   j;
  int   j;   
13 };
  };   
14 
    
15 struct AAA *pAAA;
  struct AAA *pAAA;   
16 pAAA=new AAA;
  pAAA=new AAA;   
17 这时,pAAA实际上是一个Pointer, 指向某一确定的内存地址,比如0x1234;
  这时,pAAA实际上是一个Pointer, 指向某一确定的内存地址,比如0x1234;   
18 而 pAAA->i 整体是一个int型变量,其地址是&(pAAA->i) ,'&'为取址运算符;
  而 pAAA->i 整体是一个int型变量,其地址是&(pAAA->i) ,'&'为取址运算符;   
19 那么&(pAAA->i)一定等于0x1234,因为i是结构体AAA的第一个元素。(该结构体第一个元素的地址为该结构体类型指针的地址)
  那么&(pAAA->i)一定等于0x1234,因为i是结构体AAA的第一个元素。(该结构体第一个元素的地址为该结构体类型指针的地址)   
20 而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因为sizeof(int) = 4;
  而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因为sizeof(int) = 4;
21 
    
22 这个做法的巧妙之处就是:它把“0”作为上例中的pAAA,那么 &(pAAA->j)就是j的
  这个做法的巧妙之处就是:它把“0”作为上例中的pAAA,那么 &(pAAA->j)就是j的   
23 offset啦
  offset啦
24
25 解析结果是:
  解析结果是:   
26 (s   *)0 ,将 0 强制转换为Pointer to   "s"
  (s   *)0 ,将 0 强制转换为Pointer to   "s"     
27 可以记 pS = (s *)0 ,pS是指向s的指针,它的值是0;
  可以记 pS = (s *)0 ,pS是指向s的指针,它的值是0;   
28 那么pS->m就是m这个元素了,而&(pS->m)就是m的地址,而在本例中就是offset啦
  那么pS->m就是m这个元素了,而&(pS->m)就是m的地址,而在本例中就是offset啦   
29 
    
30 再把结果强制转换为size_t型的就OK 了,size_t其实也就是int啦!!
  再把结果强制转换为size_t型的就OK 了,size_t其实也就是int啦!!    
31 
 
32 
 
33
另外:
#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER);
(TYPE *)0,将 0 强制转换为 TYPE 型指针,记 p = (TYPE *)0,p是指向TYPE的指针,它的值是0。那么 p->MEMBER 就是 MEMBER 这个元素了,而&(p->MEMBER)就是MENBER的地址,而基地址为0,这样就巧妙的转化为了TYPE中的偏移量。再把结果强制转换为size_t型的就OK了,size_t其实也就是int。
typedef __kernel_size_t size_t;
typedef unsigned int __kernel_size_t;
 
                     
                    
                 
                    
                 
  
 
                
            
         
 
         浙公网安备 33010602011771号
浙公网安备 33010602011771号