C语言结构体大小 你算对了吗 c语言结构体的大小
yuyutoo 2024-10-12 00:46 17 浏览 0 评论
C 语言中 struct 声明创建一个数据类型(结构体),能将不同类型的对象聚合到一个对象中,用名字来引用结构体的各个组成部分。结构体的所有组成部分都存放在一段连续的内存中。
如果创建一个结构体,其实际占用的内存空间大小是多少呢?示例代码如下:
struct S
{
int i;
char c;
int j;
};
要正确计算结构体大小,首先需要了解数据对齐的原理。
数据对齐
许多计算机系统对基本的数据类型的合法地址做了一些限制。要求某种类型对象的地址必须是某个值(通常为2、4、8)的倍数。这种对齐限制简化了形成处理器和内存系统之间接口的硬件设计。
对齐原则:任何占用 K 字节空间大小的基本对象,其地址必须是 K 的倍数。
那么, char 类型数据存储地址 必须是 1 的倍数。short 类型数据存储的地址为 2 的倍数,以此类推。
确保每种数据类型都是按照指定方式来组织和分配,即每种类型的数据都满足它的对齐限制,就可以保证实施对齐。
对于包含结构体的代码,编译器可能需要在字段的分配中插入间隙,以保证每个结构成员都满足它的对齐要求。而结构体本身对它的起始地址也有一些对齐要求。
由此,编译器可能需要在结构体成员内存的分配中插入间隙,保证每个结构成员都满足它的对齐要求。或者需要在结构体的末尾加入填充,从而使得结构体数组中的每个元素都会满足它的对齐要求。
结构体大小计算
情形一
结构体中间插入间隙,上述代码:
struct S
{
int i;
char c;
int j;
};
如果编译器按照最小 9 字节分配,是不可能满足成员 i 和 j 的 4 字节对齐要求的。此时,编译器会在成员 c 和 j 之间插入一个 3 字节的间隙。结果 j 的偏移量为 8,而整个结构体的大小为 12。
情形二
另外一个示例如下,其大小是多少呢?
struct S2
{
int i;
int j;
char c;
};
要正确计算这个结构体的大小,需要这样考虑:创建这个结构体的数组,每个数组元素都会满足它的对齐要求。
如果给这个结构体分配 9 个字节。考虑结构体数组 struct s2 a[4],就不能满足数组 a 的每个元素的对齐要求。假设数组的起始地址为 x,则每个元素的地址分别为 x、x+9、x+18、x+27,有三个元素不满足对齐原则。
由此,编译器会为结构 s2 分配 12 个字节,最后三个字节是补充的空间(浪费的空间),即在结构体的末尾增加填充。
情形三
结构体成员是另外一个结构体时,示例如下:
struct sta
{
int i;
int j;
char c;
};
struct stb
{
int i;
char c;
int j;
char cc;
struct sta tmp;
};
结构体 srb 的大小是多少呢?
要计算这种类型的结构体,只需要把其中的结构体成员当成一个整体即可。
先忽略 成员 tmp,结构体 stb 的大小为 16 字节(中间和末尾均需要填充间隙);结构体 sta 的大小为 12 字节。从而可以计算得出,结构体 stb 的实际大小为 16 + 12 = 28 字节。
情形四
使用编译指令,示例代码如下:
#pragma pack(1)
struct S3
{
int i;
int j;
char c;
}
#pragma pack()
注意编译指令 pragma pack 的主要作用就是改变编译器的内存对齐方式。在不使用这条指令的情况下,编译器采取默认方式对齐。
此处的两条编译预处理指令,使得在这之间定义的结构体按照 1 字节方式对齐。在本例中,使用这两条指令的效果是,编译器不会在结构体尾部填充空间了。
这个结构体的大小为 9 字节。
相关推荐
- 动态应用程序安全测试(DAST)(软件测试中的动态测试方法)
-
软件动态安全测试即动态应用程序安全测试(DAST),是在应用程序运行时通过模拟攻击来识别漏洞的过程,是一种黑盒测试技术。以下是具体介绍:工作原理爬虫发现结构:DAST工具会先通过爬虫发现整个Web...
- 如何模拟黑客攻击(Red Teaming)以测试服务器安全性
-
模拟黑客攻击(RedTeaming)是一种测试服务器安全性的有效方法,通过模拟真实黑客攻击行为,评估系统的防御能力和安全措施。RedTeaming不仅可以帮助发现潜在的安全漏洞和弱点,还可以帮助组...
- 医疗软件检测机构的收费标准是怎样的?报告内容有哪些?
-
医疗软件检测机构的收费标准通常受以下因素影响:一.软件项目规模与复杂度:...
- 打造基于 Linux 的自动化漏洞扫描平台 OpenVAS+ Redis+ PostgreSQL
-
在当前的网络安全环境中,漏洞扫描已经成为企业安全防御的第一道防线。本实战将带你一步步搭建一个基于Linux的自动化漏洞扫描平台,整合OpenVAS(Greenbone)、PostgreSQL以...
- CVE-2024-6387 漏洞检查工具(cve-2016-2183漏洞验证)
-
工具说明CVE-2024-6387_Check是一款轻量高效的检测工具,专为识别存在regreSSHion漏洞(CVE-2024-6387)的OpenSSH服务器而设计。该脚本支持快速扫描IP...
- IT运维与网络工程师必会的30个网络抓包/调试工具
-
在复杂的网络环境中,抓包与调试工具是IT运维和网络工程师的“听诊器”。它们能帮助工程师实时捕获数据包、分析流量异常、定位故障根源,甚至对抗网络攻击。本文精选30款专业工具,涵盖协议分析、流量监控、安全...
- 读红蓝攻防:技术与策略09网络杀伤链的工具
-
1.网络杀伤链的进化过程1.1.从2011年首次发布起,网络杀伤链模型发生了巨大的变化,主要原因是攻击者和攻击方法的快速演变1.1.1.攻击者不断发展他们的攻击方法1.1.2.由于杀伤链是基于...
- 什么是漏洞扫描?那些产品需要做漏洞扫描?
-
漏洞扫描是指使用漏洞扫描工具,对目标系统(如网络、服务器、应用程序等)进行自动化检测,以发现系统中可能存在的安全漏洞的过程。以下是关于漏洞扫描的详细介绍:一.需要做漏洞扫描的产品服务器:包括Web...
- 深入解析:十款不可错过的主流盗版软件检测工具推荐(2025必备)
-
随着软件盗版行为日益猖獗,企业和软件厂商亟需高效精准的盗版软件检测工具,保护知识产权和收益。2025年,盗版软件检测技术继续升级,结合AI智能分析、云端大数据比对与动态监测,实现更全面的盗版识别。以下...
- 全网疯传!20 款必备网络安全工具资源,现在免费分享
-
友情提醒:...
- 网络安全19个神器!小白到大神全靠它们
-
一、信息收集与侦察Nmap功能:网络扫描、端口探测、服务识别、操作系统检测。必学命令:nmap-sV-O<目标IP>(版本探测和系统识别)。Shodan功能:全球联网设备搜...
- 常用的软件安全测试工具,出安全检测报告第三方软件测评公司推荐
-
在信息化时代,软件产品更新迭代日益频繁,软件的安全性越来越受到用户的重视,软件产品安全与否直接关系到千家万户的隐私情况和财产安全。网站漏洞、黑客攻击同样威胁着软件的持续发展能力,而软件交付之前进行...
- 一文搞懂漏洞扫描和渗透测试的流程!!!
-
一文搞懂漏洞扫描和渗透测试的流程在网络安全领域,漏洞扫描和渗透测试是保障系统安全的重要手段,它们的流程各有特点,下面为您详细介绍:一、漏洞扫描流程...
- 从零搭建高可用的 MySQL 主从复制架构(基于 Linux 实战指南)
-
背景在生产环境中,单点MySQL数据库容易成为性能瓶颈或单点故障源。搭建MySQL主从复制架构,可以实现读写分离、高可用,提升系统的整体稳定性与扩展性。...
- 国外大神成功让Nexus4吃上安卓6.0:基本可正常使用
-
IT之家讯10月9日消息谷歌已经于10月6日正式开启了Nexus设备Android6.0Marshmallow系统的OTA升级推送。根据之前报道的消息,老一批的Nexus手机如Nexus4/Ne...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 动态应用程序安全测试(DAST)(软件测试中的动态测试方法)
- 如何模拟黑客攻击(Red Teaming)以测试服务器安全性
- 医疗软件检测机构的收费标准是怎样的?报告内容有哪些?
- 打造基于 Linux 的自动化漏洞扫描平台 OpenVAS+ Redis+ PostgreSQL
- CVE-2024-6387 漏洞检查工具(cve-2016-2183漏洞验证)
- IT运维与网络工程师必会的30个网络抓包/调试工具
- 读红蓝攻防:技术与策略09网络杀伤链的工具
- 什么是漏洞扫描?那些产品需要做漏洞扫描?
- 深入解析:十款不可错过的主流盗版软件检测工具推荐(2025必备)
- 全网疯传!20 款必备网络安全工具资源,现在免费分享
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)