在某些情况下我们想知道结构体内某个成员相对于结构体起始地址偏移了多少位。通常做法可以逐个算出个成员的大小来计算
下面我们换一种思路
通过结构体地址来换算成员的偏移量
例有如下结构体
typedef struct { char bFileName[6]; //头文件名 char isInitialization; //初始化标志 uint16_t saveindex; //存储索引 从0开始每条19个字节 }USER_WHFILE_TOP_T;
假设我们将一个结构体指针本身地址考虑为0 那么直接去获取其下成员的地址就相当于得到了偏移量
((USER_WHFILE_TOP_T*)0) //这样我们相当于获得了一个地址为0的USER_WHFILE_TOP_T类型的指针 //当然还要继续加工来获取成员变量 (((USER_WHFILE_TOP_T*)0)->saveindex) // 这里我们取最后一个成员 //然后我们要获取该成员的地址 来个&取址 &(((USER_WHFILE_TOP_T*)0)->saveindex) //最后我们要将地址转换为Uint16类型 当然考虑到本次结构体指针地址是从0开始而结构体本身并不庞大用char也可以存储,但遇到长度超过256的结构体还是要用uint16来存储 (uint16_t)(&(((USER_WHFILE_TOP_T*)0)->saveindex)) //获得该成员的偏移地址 //通过以上内容我们可以总结出一个好用的宏定义。 #define GET_STRUCT_MEMBER_OFFSET(TYPE,member) (uint16_t)(&(((TYPE*)0)->member))
本次的小知识分享就到这里!
作者:狂奔De鸵鸟