题目: 用一个宏定义FIND求一个结构体struc里某个变量相对于struc的偏移量。
如:
- struct student
- {
- int a;
- char b[20];
- double ccc;
- };
- int main()
- {
- cout << FIND(student,a) << endl;//结果为0
- cout << FIND(student,b) << endl;//结果为4
- return 0;
- }
看到这个题。我相信好多朋友都蒙了吧。都不知道该如何下手了。呵呵。。我也是。那让我们一起研究下这道题吧。
我们的目标:我们要求结构体中一个变量相对于结构体的偏移量。
我们知道的知识:
①结构体中第一个变量相对于结构体的偏移量是0,也可以说是结构体的首地址是0;
②获得地址我们可以使用取地址符"&"
首先我们先定义一个宏 #define FIND(Struct,e) ....(后面的实现在下面定义)
根据① 我们可以这样做 (Struct*)0 这里我们做了一个强制转换。将常量0转换成了Struct*型所指向的地址。这代表什么呢?我认为这就代表了结构体的首地址是0.下面有了结构体的地址了。也就是有了结构体的指针。我们就可以获得结构体的成员了。我们这样写: ((Struct*)0)->e;这样不就获得了结构体中的某个成员了吗?然后根据②我们就可以获得该成员的地址了。我们这样写:
&(((Struct*)0)->e).呵呵获得地址了吧。然而我们还知道地址输出时一般为16进制。而我们需要的为十进制,故我们需要对他进行一个强制转换。那我们该用什么类型对其转换了。int?long?还是unsigned int?其实这个就不用我们考虑了。因为库中已经有一种类型常用来表示大小了。那就是size_t .我们用它来进行强制转换就可以了。我们可以这样写:(size_t)&(((Struct*)0)->e);ok了。呵呵。这里再说明一下。其实size_t 就是unsigned int 类型。在库中是这么写的 typedef unsigned int size_t;