c++ offsetof_函数offset的用法

c++ offsetof_函数offset的用法宏offsetof标准库stddef.h定义size_toffsetof(type,member);分析C库宏offsetof(type,member)会生成一个类型为size_t的整型常量,它是一个结构成员(member)相对于结构(type)开头的字节偏移量。成员是由member给定的,结构的名称是在type中给定的。type–这是一个参数class类型,是结…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

宏offsetof

标准库stddef.h

定义 size_t offsetof(type, member);

分析

C 库宏 offsetof(type, member) 会生成一个类型为 size_t 的整型常量,它是一个结构成员(member)相对于结构(type)开头的字节偏移量。成员是由 member 给定的,结构的名称是在 type 中给定的。

type — 这是一个 参数class类型,是结构体的名字,第二个参数member是结构体成员的名字,是一个有效的成员指示器。该宏返回结构体class中成员member的偏移量。偏移量是size_t类型的。

member — 这是一个 class 类型中的成员指示器,就是指定的class里的一个成员量。通常通过member得到type的起始地址,即指向type类型的指针。

该宏返回类型为 size_t 的值,表示 type 中成员的偏移量,是一个无符号整数类型数值,是 sizeof 关键字的结果。需要注意的是,这里在实际环境中会涉及到C语言内存对齐机制。

下面的实例演示了 offsetof() 宏的用法。

#include

#include

struct address {

char name[50];

char nationality[50];

int phone;

};

int main()

{

printf(“address 结构中的 name 偏移 %d 字节。\n”,

offsetof(struct address, name));

printf(“address 结构中的 nationality 偏移 %d 字节。\n”,

offsetof(struct address, nationality));

printf(“address 结构中的 phone 偏移 %d 字节。\n”,

offsetof(struct address, phone));

return(0);

}

编译并运行上面的程序,这将产生以下结果:

address 结构中的 name 偏移 0 字节。

address 结构中的 nationality 偏移 50 字节。

address 结构中的 phone 偏移100 字节。

应用

在实际的使用中,比较经典的情况:已知一个已经分配空间的结构体对象指针A中的某个成员B,使用offsetof宏,可根据B在A中的偏移量,获取该结构体指针对象A的首地址,从而进一步使用A。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/172109.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 一个低级的ORA-01017错误

    一个低级的ORA-01017错误事件缘由:使用sys账户创建了一个数据清理的存储过程,再创建一个Oraclejob定时运行这个存储过程,用于做表数据的清理。第二天看表数据未删除,说明job执行有错,打算使用sys账号登录查看job运行情况,反复输入sys账户信息,总提示ORA-01017,1.尝试改sys用户密码,重试报错依旧。2.使用sys登录GC,报错相同。使用普通用户登录正常。3.数据库服务器上使用sq

    2022年6月1日
    33
  • 数据结构 图的邻接矩阵

    数据结构 图的邻接矩阵图的邻接矩阵的存储方式是用两个数组来实现的,一个一维数组存储顶点信息,一个二维数组存储线(无向图)或弧(有向图)的信息。设图G有n个顶点,则邻接矩阵是一个n×n的方阵,定义为:无向图的邻接矩阵,两个顶点有边则为1,否则,为0;因为是无向图arc[i][j]=arc[j][i],所以矩阵为对称矩阵,对角线为自己到自己的边,邻接矩阵中,行之和或者列之和都为各顶点度的总数。设图G有是网图,有n个…

    2022年6月28日
    22
  • oracle11g的standby性能分析报告statpack安装

    一般常见的分析standbydatabase的性能问题的方法就是通过动态性能视图来判断,从11g开始,随着ActiveDataGuard功能的出现,早期的Statspack工具可以在stand

    2021年12月24日
    60
  • ThinkPHP5+小程序商城 网盘视频

    ThinkPHP5+小程序商城 网盘视频

    2021年10月31日
    43
  • navicat15.0.22激活码【在线注册码/序列号/破解码】

    navicat15.0.22激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    88
  • clion2022 激活【中文破解版】「建议收藏」

    (clion2022 激活)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1TCF2R91JZ-eyJsa…

    2022年3月31日
    2.2K

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号