Chinaunix首页 | 论坛 | 博客
  • 博客访问: 118723
  • 博文数量: 27
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 85
  • 用 户 组: 普通用户
  • 注册时间: 2014-08-30 13:49
文章分类
文章存档

2017年(3)

2016年(1)

2015年(3)

2014年(20)

我的朋友

分类: C/C++

2014-09-28 16:54:54

P { margin-bottom: 0.21cm; }

C语言中存在一种情况,就是在一个大的结构体中,会有一个小的结构体成员变量(而非指针),这个小的结构体只有两个成员,一个是next,一个是prev,具体如下:

struct list_head {

struct list_head *next;

struct list_head *prev;

}

有一个奇妙的用法是,我们可以根据大结构体中小结构体的地址,得到大结构体的地址:

#define list_entry(entry,type,member) \

((type *)((char *)(entry)-(unsigned long)(&((type *)NULL)->member)))

对这句话的解析:

将以0地址开始的位置转换为type *类型,那么它的member的地址,就是相对于0地址的偏移,将entry的地址减去该member的相对偏移量就是大结构体所在的地址,(entry是大结构体中小结构体的地址)然后将其转换成type * 类型。
ps1
:需要从后往前看,entrylist_head *型,memberlist_head型,type是大结构体的类型
ps2 : 我们知道NULL的值为0

阅读(1249) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~