计算结构体成员在结构体中的偏移量

149 篇文章 2 订阅
111 篇文章 1 订阅

一 方式1:采用offsetof宏

#include <stdio.h>
#include <stddef.h>
struct PP {
    char a;
    int b;
};
int main() {
    struct PP pp;
    printf("%zd\n", offsetof(struct PP, b));    // 输出4
 
    return 0;
}

以上方法是调用系统宏offsetof,此宏是被定义在头文件stddef.h中,需要注意是编译器采用了内部填充机制,即上述代码在centos 7 64机器编译运行后,输出结果是4,char a后编译器填充了3个字节的数据(应该都是0)。此方法不能对位域取offset,即将上面代码int b换成int b:8,会编译出错。

二 方式2:自定义offsetof宏

#define OFFSETOF(type, f) ((size_t)((char *)&((type *)0)->f - (char *)(type *)0))

方法2假定地址0开始处有一个type类型结构体,由于没有对地址0做取值操作,因此不会发生内存访问错误,但此方法不能保证可移植性,也不能对位域取偏移量。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
结构是由多个不同类型的变组成的数据类型,每个变在内存占用不同的空间。结构类型地址偏移指的是结构每个变的地址相对于结构起始地址的偏移。 在C语言,可以使用指针来访问结构的变偏移可以通过指向结构的指针加上变偏移计算。例如,假设有以下结构: ```c struct student { char name[20]; int age; float score; }; ``` 可以定义一个指向该结构的指针,并使用指针来访问结构的变: ```c struct student stu; struct student *p = &stu; ``` 访问结构的变可以使用点运算符或箭头运算符,例如访问name变偏移可以使用以下代码: ```c int name_offset = (int)&((struct student *)0)->name; ``` 这个表达式,(struct student *)0将0强制转换为指向结构类型的指针,然后取出name成员的地址,最后将其转换为int类型。这个偏移可以用来计算结构name变的地址。 类似地,可以计算age和score变偏移: ```c int age_offset = (int)&((struct student *)0)->age; int score_offset = (int)&((struct student *)0)->score; ``` 使用偏移可以在不知道结构起始地址的情况下访问结构的变。例如,可以使用以下代码访问结构的name变: ```c char *name_ptr = (char *)((int)p + name_offset); ``` 这个表达式,将指向结构的指针p转换为int类型,然后加上name变偏移,最后将结果转换为指向char类型的指针。这个指针可以用来访问结构的name变

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值