define宏定义的这句话是什么意思呢?


在一本书上看到了这段代码,其含义是求一个结构体成员相对于结构体开始位置的偏移量,但不理解其含义,求大牛解释.


 struct{
    int a;
    double b[20];
    double c;
}struc;

#define FIND(struc,c) ((size_t)&((struc *)0)->e)

程序员 C++ 算法 面试题

Pxjjj 10 years, 3 months ago

struct 结构体对象的内存位置是连续的,假设整个对象的起始地址是 0 (struc *)0 这里做了强制转换;那么我们首先解引用取得结构体某个元素的值


 struc* p = (struc *)0;
double c = p->c;

然后再获得元素的地址,这个地址就是相对于整个结构体对象内存的起始位置的


 size_t offset =(size_t)( &c - (size_t)0);

题主你看的是扫描版的么?

jas32 answered 10 years, 3 months ago

这个宏应该是参考 linux offsetof 宏定义:
#define offsetof(TYPE, MEMBER) (size_t)(&(((TYPE*)0)->MEMBER))

这个宏的分析:

(TYPE*)0 0 地址强转为 TYPE 类型的指针

((TYPE*)0)->MEMBER 获取 TYPE 结构体中的成员 MEMBER

&(((TYPE*)0)->MEMBER) 获取成员 MEMBER 的地址, 通常我们 拿这个地址值减去整个结构体的起始地址即可得出 MEMBER 的偏移地址 , 但因为现在 结构体的起始地址 0 (这个 0 就是整个宏定义的精华所在), 所以获取的地址即为实际的偏移地址(减去 0 等于没减嘛)

小白白白白 answered 10 years, 3 months ago

Your Answer