首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

结构对齐

详细我们下面再介绍 对齐规则 1)结构体总长度; 2)结构体内各数据成员的内存对齐,即该数据成员相对结构的起始位置; 细分步骤: 1.确定结构第一个结构变量位于结构0偏移的位置 2.对齐其他成员变量通过对齐数...对齐数就是编译器默认的一个对齐数与该结构中的成员变量大小中的较小值 3.结构图总大小是最大对齐数的整数倍(成员、结构都有自己的对齐数) 虽然到目前为止你也没看懂我写的是什么,但下面我将详细介绍对齐数...对齐数 首先明确四个概念 成员对齐值:基本数据类型的对齐结构对齐值:数据成员对齐值最大的值 指定对齐值:系统默认或者我们使用 \#prama pack(value) 指定对齐值 value 有效对齐值...//对齐数 = 2 有效对齐数min(2,4); 然后我们再看结构对齐数 因为成员基本类型对齐数 最大是4 所以该结构对齐值是4 min(4,4) 所以该结构的有效对齐值是4 那我们现在就把这个结构对齐...= 0; 总长度就是我们结构对齐之后的长度 实际对齐长度就是结构的有效对齐值 选择最好的对齐字节数值 如何选择最好的对齐数值 设置不同的字节对齐方式对于数据的存储空间来说有不同的影响,在和变量自身对齐值为整数数关系下

22220

结构对齐规则及为什么会有结构对齐

前言:   大家在学习结构中,在计算结构大小时想必会很疑惑,为什么结构的大小不是按照常理像数组一样一个字节一个字节的挨在一起放?今天带大家一起深入探讨一下背后的规则和原因。...结构对齐规则:    结构对齐其实就是所有成员变量都要对齐对齐数整数倍的地址处   首先认识一下默认对齐数的概念,每个编译器都有默认对齐数,我这里使用的是vs2022,它的默认对齐数是8。  ...接下来我举两个实例: 我定义一个如下结构: 接下来开始计算每个成员变量的对齐数。...第二个对齐数是1,任何位置都是1的整数倍,所以直接接在a的后面1个字节,但最后结构的大小可不是5 因为要满足结构体总大小是最大对齐数的整数倍,此时最大对齐数是4,5不是4的整数倍,8才是4的整数倍,...注意如果结构里面嵌套了结构,那么嵌套在里面的结构对齐数是: 该结构的最大对齐数。 如下图所示: 为什么要结构对齐?   从上面的例子不难看出,结构对齐是会浪费空间的,可是为什么要这样做呢?

36310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    结构字节对齐

    结构字节对齐       在用sizeof运算符求算某结构所占空间时,并不是简单地将结构中所有元素各自占的空间相加,这里涉及到内存字节对齐的问题。...对于结构的字节对齐主要有下面两点:       1)结构每个成员相对结构首地址的偏移量(offset)是对齐参数(这句话中的对齐参数是 取每个变量自身对齐参数和系统默认对齐参数#pragma pack...补充:如果结构A中还要结构B,那么B的对齐方式是选它里面最长的成员的对齐方式 所以计算结构大小要走三步,首先确定是当前程序按照几对齐(参照1,2点),接着计算每个结构变量的大小和偏移(参照3,5...从上面可以发现,在windows(32)/VC6.0下各种类型的变量的自身对齐参数就是该类型变量所占字节数的大小,而在 linux(32)/GCC下double类型的变量自身对齐参数是4,是因为linux...(32)/GCC下double类型的变量自身对齐参数是4,如果是在Linux(64)下,则double类型的自身对齐参数是8。

    1.3K60

    C语言结构字节对齐 | 结构与联合

    结构字节对齐 结构的空间大小: 结构为了保证CPU的访问效率,默认采用内存对齐机制 对齐标准为结构中基础数据类型的成员最大值 对齐标准和成员申明顺序有关 #include #...3.结构对齐规则 (1)第一个成员在相比于结构变量存储起始位置偏移量为0的地址处。...(2)从第二个成员开始,在其自身对齐数的整数倍开始存储(对齐数=编译器默认对齐数和成员字节大小的最小值,VS编译器默认对齐数为8)。 (3)结构变量所用总空间大小是成员中最大对齐数的整数倍。...(4)当遇到嵌套结构的情况,嵌套结构对齐到其自身成员最大对齐数的整数倍,结构的大小为当下成员最大对齐数的整数倍。...结构的偏移量:某一个成员的实际地址和结构首地址之间的距离。 结构字节对齐:每个成员相对于结构首地址的偏移量都得是当前成员所占内存大小的整数倍,如果不是会在成员前面加填充字节。

    2.3K10

    结构的内存对齐规则

    1.结构的内存对齐规则 1.第一个成员在与结构变量偏移量为0的地址处。 2.其他成员变量都放在对齐数(成员的大小和默认对齐数的较小值)的整数倍的地址处。...对齐数=编译器默认的一个对齐数与该成员大小的较小值。(VS中默认的对齐数是8) 3.结构体总大小为最大对齐数(每个成员变量都有一个对齐数 )的整数倍。...4.如果嵌套了结构的情况,嵌套的结构对齐到自己的最大对齐数的整数倍处,结构的整体大小就是所有最大对齐数(含嵌套结构对齐数)的整数倍。...2.性能原因: 数据结构(尤其是栈)应该尽可能地在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要作两次内存访问;而对齐的内存访问仅需要一次访问。...总的来说: 结构的内存对齐是拿空间来换取时间的做法 既然这样,那在设计结构的时候,我们既要满足对齐,又要节省空间,如何做到:让占用空间小的成员尽量集中在一起。

    47210

    C语言——结构类型(二)【结构体内存对齐结构数组】

    这就是因为结构类型的变量在开辟内存的时候,要遵循结构体内存对齐,只有对齐到符合的地址处时,才会开始为成员分配内存 在了解如何对齐前,我们先来了解对齐数这个概念 ① 一个变量的对齐数 = 编译器默认的对齐数...与 该成员变量大小之间的较小值 ②如果嵌套了结构类型的成员,则这个成员的对齐数就是 这个嵌套的结构的自身成员中的最大对齐数 ●VS中默认的对齐数是8 ●Linux中gcc没有默认对齐数(即对齐数就是成员变量的自身大小...) 接下来我们就来介绍一下结构体内存对齐的规则: 1,结构的第一个成员对齐到与结构变量起始位置的偏移量为0的地址处(简单来说就是第一个成员变量的内存从起始位置开始分配) 2,其他成员变量要对齐到...与起始位置的偏移量为这个变量的对齐数的整数倍的地址处,然后再开始分配内存 3,结构的总大小应该为 所有成员中最大对齐数 的整数倍 2,例子分析 我们计算结构的大小的一般流程如下 了解了上面的知识以后...birthday的对齐数 2,birthday成员的大小,birthday也是一个结构,也要用结构体内存对齐的方式来计算大小 具体分配如下: 二,结构数组 1,什么是结构数组 结构数组,

    41610

    C语言如何计算结构大小(结构的内存对齐

    前言: 结构的内存对齐是有关结构体内容的很重要一个知识点,主要考察方式是计算结构的字节大小。...结构到底如何计算? 二、结构对齐规则 我们经过上面的分析,发现结构成员不是按照顺序在内存中连续存放的,而是有一定的对齐规则,接下来我们就研究结构的内存规则。...结构的第一个成员永远放在相较于结构变量的起始未知的偏移量为0的位置 从第二个成员开始,往后的每个成员都要对齐到某个对齐数的整数倍处。...(对齐数:结构成员自身大小和默认对齐数的较小值)VS上默认对齐数是8,gcc没有默认对齐数,对齐数就是变量本身的大小。...结构的总大小,必须是最大对齐数的整数倍,最大对齐数是:所有成员的对齐数中最大的值 如果嵌套了结构的情况,嵌套的结构对齐到自己的最大对齐数的整数倍处,结构的整体大小就是所有最大对齐数(含嵌套结构对齐

    10510

    C进阶:结构的内存对齐

    性能原因: 数据结构(尤其是栈)应该尽可能地在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要作两次内存访问;而对齐的内存访问仅需要一次访问。...总体来说: 结构的内存对齐是拿空间来换取时间的做法。 二.内存对齐规则 1. 第一个成员在与结构变量偏移量为0的地址处。 2....结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。 4....如果嵌套了结构的情况,嵌套的结构对齐到自己的最大对齐数的整数倍处,结构的整体大小就是所有最大对齐数(含嵌套结构对齐数)的整数倍。 什么意思呢?...1中的一样,但顺序却不一样; 不过不用担心,他们内存对齐的规则还是一样的; vs2022 打印结果: 通过上面两个例子,我们发现,即使结构的成员类型相同,结构的内存大小最后可能还是不同,我们最好把小类型的写在一起

    20010

    c语言结构字节对齐详解

    1.什么是字节对齐 在c语言的结构里面一般会按照某种规则去进行字节对齐。...st1在32位下是按照4个字节来对齐的,在64位下则是按照8个字节来对齐的,结构st2则不管32位还是64位则都是按照1个字节对齐的。...那么我们可以总结出对齐规则如下: 在所有结构成员的字节长度都没有超出操作系统基本字节单位(32位操作系统是4,64位操作系统是8)的情况下,按照结构中字节最大的变量长度来对齐; 若结构中某个变量字节超出操作系统基本字节单位...3.手动设置对齐 什么情况下需要手动设置对齐: 设计不同CPU下的通信协议,比如两台服务器之间进行网络通信,共用一个结构时,需要手动设置对齐规则,确保两边结构体长度一直; 编写硬件驱动程序时寄存器的结构...//这里计算sizeof(st3)=5 4.结构比较方法 可以使用内存比较函数memcpy进行结构比较,但因为结构对齐可能会有填充位不一致的情况,此时需要注意: 设置为1个字节对齐,使它没有空位

    2.6K10

    【C语言】结构的大小是如何计算的?(结构对齐

    为了提高内存访问的效率,编译器会对结构进行对齐。...对齐的方式是按照成员的类型和顺序来进行的。 对齐的目的是为了让结构成员的地址能够被整除,从而提高内存访问的速度。 还不清楚结构成员的对齐方式的同学不用着急,我会在本文第三部分展开详解。...三.利用结构对齐规律计算结构大小 1.结构对齐规则: 要知道结构大小是如何计算的,首先需要了解结构对齐规则: 1、第一个成员在于结构变量偏移量为0的地址处。...4、针对嵌套结构,嵌套的结构体要对齐到自己最大对齐数的整数倍处,结构体总大小是所有对齐数的最大值(包含嵌套结构对齐数)的整数倍。...修改后的运行结果则变成了: 画图理解一下: 注意,当我们将默认对齐数改为1时,即: #pragma pack(1) 则相当于没有对齐数,结构的大小就是按顺序累加了,如: 将默认对齐数改为1后,如上结构的大小就变成

    84010

    结构对齐+联合体+位段

    结构对齐 前言 我们都知道C语言中每种内置类型都有相应的大小,而结构是基本类型的复合,是自定义类型,那么它的大小是如何计算的呢?是否是把结构体内的基本类型的相加就行了呢?...为了深入了解结构的大小事如何计算的,即不得不了解结构对齐结构对齐 要想知道如何计算,就得先知道结构对齐的规则: 第一个成员在与结构变量偏移量为0的地址处。...如果嵌套了结构的情况,嵌套的结构对齐到自己的最大对齐数的整数倍处,结构的整 大小就是所有最大对齐数(含嵌套结构对齐数)的整数倍 对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。...按照结构对齐规则,可知结构的第一个成员是从偏移量为0的地址处开始存储,因为c1的类型为char所以只占一个字节,而结构的第二个成员是要对齐对齐数的整数倍处,我们的先求出对齐数,按照结构对齐的第二条规定...而整个结构的大小就是所有最大对齐数(含嵌套结构对齐数)的整数倍,此时结构的偏移量为32正好是所有最大对齐数的整数倍。所以结构的大小为32. 控制台的输出 为什么存在内存对齐?

    20720

    【C语言】详解结构(中)(结构的内存对齐,重点中的重点)

    结构的内存对齐(重点) 回想一下数组在内存中是连续存放的,那我们就会提出一个疑问,结构难道也会是这样的吗?...1.2 内存对齐的规则 结构的第⼀个成员对齐到和结构变量起始位置偏移量为0的地址处 其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。...VS 中默认的值为 8 Linux中 gcc 没有默认对齐数,对齐数就是成员自身的大小 结构体总大小为最大对齐数(结构中每个成员变量都有⼀个对⻬数,所有对⻬数中最⼤的)的整数倍。...如果嵌套了结构的情况,嵌套的结构成员对⻬到⾃⼰的成员中最⼤对齐数的整数倍处,结构的整体大小就是所有最大对齐数(含嵌套结构中成员的对⻬数)的整数倍。...,得在三条规则的基础上,再多加一条规则:如果嵌套了结构的情况,嵌套的结构成员对⻬到⾃⼰的成员中最⼤对齐数的整数倍处,结构的整体大小就是所有最大对齐数(含嵌套结构中成员的对⻬数)的整数倍。

    10010

    结构成员在内存中的对齐方式

    以下我会举两个结构的例子,分别画图的方式表达对齐的原则。 结构对齐的公式 记住以下这些规则,把结构往里面套就可以了。...结构对齐的原则就是牺牲空间的方式来减少时间的消耗,空间用完还可以复用,而时间过去了就再也不会回来了。...以 #pragma pack(x) 中 x 的大小和结构中占用空间最大的成员做比较,取小值为 n(外对齐依据) 以 n 值和结构每个成员比较,得出结果列表为 m[x] 根据每个成员的大小依次向内存中填充数据...案例一 我们来看一个简单的案例,#pragma pack(4) 为 4,结构中有 char、short、int 3个成员,其对齐的方式如下图表示: #include #pragma.../struct sizeof(DATA) = 8 案例二 这个案例中,我们把 #pragma pack(8) 设定为 8,结构中有三个成员 char、double、int,其对齐方式如下图: #include

    19630

    Linux 内核 内存管理】物理内存组织结构 ④ ( 内存区域 zone 简介 | zone 结构源码分析 | zone 结构源码 )

    文章目录 一、内存区域 zone 简介 二、zone 结构源码分析 1、watermark 成员 2、lowmem_reserve 成员 3、zone_pgdat 成员 4、pageset 成员 5...内存管理系统 3 级结构 : ① 内存节点 Node , ② 内存区域 Zone , ③ 内存页 Page , Linux 内核中 , 使用 上述 3 级结构 描述 和 管理 " 物理内存 "...; 一、内存区域 zone 简介 ---- " 内存节点 " 是内存管理的 最顶层结构 , " 内存节点 " 再向下划分 , 就是 " 内存区域 " zone , " 内存区域 " 在 Linux 内核中使用...struct zone 结构类型进行描述 , zone 枚举定义在 Linux 内核源码的 linux-4.12\include\linux\mmzone.h#350 位置 ; 每个 " 内存区域..." , 都使用 1 个 zone 结构 描述 ; 二、zone 结构源码分析 ---- 1、watermark 成员 watermark 表示 " 页分配器 " 使用的 水线 ; /* zone

    4.5K30

    Linux 内核Linux 内核源码结构 ( 下载 Linux 内核源码 | 使用 VSCode 阅读 Linux 内核源码 )

    文章目录 一、下载 Linux 内核源码 二、使用 VSCode 阅读 Linux 内核源码 一、下载 Linux 内核源码 ---- 参考 【Linux 内核】编译 Linux 内核 ① ( 下载指定版本的...Linux 内核源码 | Linux 内核版本号含义 | 主版本号 | 次版本号 | 小版本号 | 稳定版本 ) 博客 , 下载 Linux 5.6.18 版本的内核源码 ; 5.x 内核源码下载地址...: https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/ Linux 内核 5.6.18 版本 : https://mirrors.edge.kernel.org...参考 【错误记录】解压 Linux 内核报错 ( Can not create symbolic link : 客户端没有所需的特权 | Windows 中配置 7z 命令行执行解压操作 ) 博客 ;...不同版本的 Linux 内核 区别 : 系统调用 : 其系统调用是相同的 , 新的版本可能会增加新的系统调用 ; 设备文件 : 各内核版本的设备文件都是相同的 , 但是 内部接口 可能不同 ; 二、使用

    23.5K32

    Linux 内核Linux 内核源码结构 ( 下载 Linux 内核源码 | 使用 VSCode 阅读 Linux 内核源码 )

    文章目录 一、下载 Linux 内核源码 二、使用 VSCode 阅读 Linux 内核源码 一、下载 Linux 内核源码 ---- 参考 【Linux 内核】编译 Linux 内核 ① ( 下载指定版本的...Linux 内核源码 | Linux 内核版本号含义 | 主版本号 | 次版本号 | 小版本号 | 稳定版本 ) 博客 , 下载 Linux 5.6.18 版本的内核源码 ; 5.x 内核源码下载地址...: https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/ Linux 内核 5.6.18 版本 : https://mirrors.edge.kernel.org...不同版本的 Linux 内核 区别 : 系统调用 : 其系统调用是相同的 , 新的版本可能会增加新的系统调用 ; 设备文件 : 各内核版本的设备文件都是相同的 , 但是 内部接口 可能不同 ; 二、使用...按钮 , 此时就可以在 VSCode 中阅读 Linux 内核源码 ;

    21.4K30

    Linux 内核】进程管理 task_struct 结构 ① ( task_struct 结构引入 | task_struct 代码示例 )

    文章目录 一、task_struct 结构 二、task_struct 结构代码示例 一、task_struct 结构 ---- 在 Linux 操作系统 中 , 进程 作为 调度的实体 , 需要将其抽象为..." 进程控制块 " , 英文全称 " Progress Control Block " , 简称 PCB ; 在 Linux 内核 中 , " 进程控制块 " 是通过 task_struct 结构...进行描述的 ; Linux 内核中 , 所有 进程管理 相关算法逻辑 , 都是基于 task_struct 结构的 ; task_struct 结构linux-5.6.18\include\linux...\sched.h 头文件中定义 , 第 629 ~ 1300 行就是 struct task_struct 结构定义的代码 ; 二、task_struct 结构代码示例 ---- struct..._*, siglock protected: */ unsigned long jobctl; /* Used for emulating ABI behavior of previous Linux

    3.5K30
    领券