结构体类型对齐问题----例题及方法详细解析

简介: 结构体类型对齐问题----例题及方法详细解析
#include<stdio.h>
//struct A
//{
//    int a;
//    short b;
//    int c;
//    char d;
//};
//struct B
//{
//    int a;
//    short b;
//    char c;
//    int d;
//};
//int main()
//{
//    struct A sa = { 0 };
//    struct B sb = { 0 };
//    printf("%d\n", sizeof(sa));//16=4+2+2+4+1+3
//    printf("%d\n", sizeof(sb));//12=4+2+1+1+4
//}
/*#pragma pack(4)*///编译选项,按照四个字节对齐
//从第二个变量开始,看开始位置的下标是否是第二个元素变量类型的整数倍,是的话,就放,不是的话
//浪费到最大对齐数的整数倍再放,第三个变量,看开始位置的下标是否是第二个元素变量类型的整数倍
//是的话,就放,不是的话,浪费到最大对齐数的整数倍再放...
//所占字节数是不是最大对齐数的整数倍呢?是的话就是所占字节,不是的话就浪费到最大对齐数
//的整数倍为止
//如
//int main()
//{
//    struct A
//    {
//        short a;//下标为0开始放                                      放0-1
//        char d;//下标为2,是1的整数倍 ,不用浪费,下标为2开始放      放2
//        long b;//下标为3,不是4的整数倍,浪费到4,下标为4开始放      放4-7
//        long c;//下标为8,是4的整数倍,不用浪费,下标为8开始放       放8-11
//               //下标为11,总共是12字节,是最大整数4的整数倍,不用浪费  放12
//    };
//    struct B
//    {
//        long b;//下标为0开始放                                        放0-3
//        short c;//下标为4,是2的整数倍,不用浪费,下标为4开始放        放4-5
//        char d;//下标为6,是1的整数倍,不用浪费,下标为6开始放        放6
//        long a;//下标为7,不是4的整数倍,浪费到8,下标为8开始放,      放8-11
//               //下标为11,总共是12字节,是最大整数4的整数倍,不用浪费   放12
//    };
//    struct C
//    {
//        short c;//下标为0                                             放0-1
//        long b;//下标为2,不是4的整数倍,需要浪费,下标为4开始放      放4-7
//        char d;//下标为7,是1的整数倍,不需要浪费,下标为7开始放      放8
//        long a;//下标为9,不是4的整数倍,需要浪费,下标为12开始放     放12-15
//               //下标为11,总共是12字节,是最大整数4的整数倍,不用浪费   放16
//    };
//    struct A stA;
//    struct B stB;
//    struct C stC;
//    printf("%d %d %d", sizeof(stA), sizeof(stB), sizeof(stC) );//12 12 16-----
//    //看下标,下标满足下一个变量类型的整数倍才可以放
//    //str A中2+1(1是任何数的整数倍,不用浪费)+2(此时下标为2,需要浪费到4的整数倍,下标为4
//    // 处开始放)+4(int型)+4(int型)=12(是最大对齐数4的整数倍,不用浪费)
//    //str B中4+1(此时下标为3,short型需要是2的整数倍,浪费到下标为4)+1(1是任何数的整数倍,
//    //不用浪费)+(此时下标为5,long型需要是4的整数倍,浪费到下标为8)+3(此时为9个字节,不是最
//    //大对齐数4的整数倍,需要浪费到12)
//    return 0;
//}


相关文章
|
9月前
|
监控 安全 网络安全
深入解析PDCERF:网络安全应急响应的六阶段方法
PDCERF是网络安全应急响应的六阶段方法,涵盖准备、检测、抑制、根除、恢复和跟进。本文详细解析各阶段目标与操作步骤,并附图例,助读者理解与应用,提升组织应对安全事件的能力。
1147 89
|
10月前
|
存储 Java 开发者
浅析JVM方法解析、创建和链接
上一篇文章《你知道Java类是如何被加载的吗?》分析了HotSpot是如何加载Java类的,本文再来分析下Hotspot又是如何解析、创建和链接类方法的。
483 132
|
8月前
|
编解码 缓存 Prometheus
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
本期内容为「ximagine」频道《显示器测试流程》的规范及标准,我们主要使用Calman、DisplayCAL、i1Profiler等软件及CA410、Spyder X、i1Pro 2等设备,是我们目前制作内容数据的重要来源,我们深知所做的仍是比较表面的活儿,和工程师、科研人员相比有着不小的差距,测试并不复杂,但是相当繁琐,收集整理测试无不花费大量时间精力,内容不完善或者有错误的地方,希望大佬指出我们好改进!
488 16
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
|
10月前
|
安全 Ubuntu Shell
深入解析 vsftpd 2.3.4 的笑脸漏洞及其检测方法
本文详细解析了 vsftpd 2.3.4 版本中的“笑脸漏洞”,该漏洞允许攻击者通过特定用户名和密码触发后门,获取远程代码执行权限。文章提供了漏洞概述、影响范围及一个 Python 脚本,用于检测目标服务器是否受此漏洞影响。通过连接至目标服务器并尝试登录特定用户名,脚本能够判断服务器是否存在该漏洞,并给出相应的警告信息。
545 84
|
7月前
|
JSON 监控 网络协议
Bilibili直播信息流:连接方法与数据解析
本文详细介绍了自行实现B站直播WebSocket连接的完整流程。解析了基于WebSocket的应用层协议结构,涵盖认证包构建、心跳机制维护及数据包解析步骤,为开发者定制直播数据监控提供了完整技术方案。
|
7月前
|
安全 IDE Java
重学Java基础篇—Java Object类常用方法深度解析
Java中,Object类作为所有类的超类,提供了多个核心方法以支持对象的基本行为。其中,`toString()`用于对象的字符串表示,重写时应包含关键信息;`equals()`与`hashCode()`需成对重写,确保对象等价判断的一致性;`getClass()`用于运行时类型识别;`clone()`实现对象复制,需区分浅拷贝与深拷贝;`wait()/notify()`支持线程协作。此外,`finalize()`已过时,建议使用更安全的资源管理方式。合理运用这些方法,并遵循最佳实践,可提升代码质量与健壮性。
191 1
|
7月前
|
传感器 监控 Java
Java代码结构解析:类、方法、主函数(1分钟解剖室)
### Java代码结构简介 掌握Java代码结构如同拥有程序世界的建筑蓝图,类、方法和主函数构成“黄金三角”。类是独立的容器,承载成员变量和方法;方法实现特定功能,参数控制输入环境;主函数是程序入口。常见错误包括类名与文件名不匹配、忘记static修饰符和花括号未闭合。通过实战案例学习电商系统、游戏角色控制和物联网设备监控,理解类的作用、方法类型和主函数任务,避免典型错误,逐步提升编程能力。 **脑图速记法**:类如太空站,方法即舱段;main是发射台,static不能换;文件名对仗,括号要成双;参数是坐标,void不返航。
252 5
|
10月前
|
数据可视化 项目管理
个人和团队都好用的年度复盘工具:看板与KPT方法解析
本文带你了解高效方法KPT复盘法(Keep、Problem、Try),结合看板工具,帮助你理清头绪,快速完成年度复盘。
725 7
个人和团队都好用的年度复盘工具:看板与KPT方法解析
|
9月前
|
人工智能 监控 数据可视化
提升开发效率:看板方法的全面解析
随着软件开发复杂度提升,并行开发模式下面临资源分配不均、信息传递延迟及缺乏全局视图等瓶颈问题。看板工具通过任务状态实时可视化、流量效率监控和任务依赖管理,帮助团队直观展示和解决这些瓶颈。未来,结合AI预测和自动化优化,看板工具将更高效地支持并行开发,成为驱动协作与创新的核心支柱。
|
10月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
695 14

热门文章

最新文章

推荐镜像

更多
  • DNS