我是靠谱客的博主 现代大山,最近开发中收集的这篇文章主要介绍linux内核 宏offsetof 解析,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

最后

以上就是现代大山为你收集整理的linux内核 宏offsetof 解析的全部内容,希望文章能够帮你解决linux内核 宏offsetof 解析所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部