c++结构体内存对齐

结构体内存对齐

试试运行下面的例子

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

using namespace std;

struct A{
    char c;
    int i;
};


struct B{
    char c; 
    int i;  
    double d; 
};


struct C{
    char c;
    int i;
    double d;
    char c1;
};

int main(){
    printf("sizeof(A): %d\n", sizeof(struct A));
    printf("sizeof(B): %d\n", sizeof(struct B));
    printf("sizeof(C): %d\n", sizeof(struct C));

    system("pause");
    return 0;
}


以上输出的结果并非实际成员占用的字节数,这就是结构体的内存对齐!

结构体内存对齐原因

1.移植原因

"不是所有的硬件平台都能访问任意地址上的任意数据;某些硬件平台只能在某些特定地址处取某些特定的数据,否则就会抛出硬件异常"。也就是说在计算机在内存读取数据时,只能在规定的地址处读数据,而不是内存中任意地址都是可以读取的。

  1. 效率原因

正是由于只能在特定的地址处读取数据,所以在访问一些数据时,对于访问未对齐的内存,处理器需要进行两次访问;而对于对齐的内存,只需要访问一次就可以。 其实这是一种以空间换时间的做法,但这种做法是值得的。

结构体对齐规则

1.第一个成员在结构体变量偏移量为0 的地址处,也就是第一个成员必须从头开始。

2.其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。对齐数为编译器默认的一个 对齐数与该成员大小中的较小值。vs中默认值是8 Linux默认值为4(可以通过#pragma pack (N) 修改,使用#pragma pack(show) 可以查看对齐值),但修改时N的取 值只能设置成1, 2,4,8,16.

3.结构体总大小为最大对齐数的整数倍。(每个成员变量都有自己的对齐数)

4.如果嵌套结构体,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是 所有最大对齐数(包含嵌套结构体的对齐数)的整数倍

结构体对齐示例


相关推荐
做怪小疯子8 小时前
LeetCode 热题 100——哈希——最长连续序列
算法·leetcode·哈希算法
Dream it possible!9 小时前
LeetCode 面试经典 150_二叉树_二叉树展开为链表(74_114_C++_中等)
c++·leetcode·链表·面试·二叉树
做怪小疯子9 小时前
LeetCode 热题 100——双指针——三数之和
算法·leetcode·职场和发展
yi碗汤园9 小时前
【一文了解】C#反射
开发语言·unity·c#
高山上有一只小老虎9 小时前
等差数列前n项的和
java·算法
sin_hielo9 小时前
leetcode 2536
数据结构·算法·leetcode
flashlight_hi9 小时前
LeetCode 分类刷题:203. 移除链表元素
算法·leetcode·链表
py有趣9 小时前
LeetCode算法学习之数组中的第K个最大元素
学习·算法·leetcode
吗~喽9 小时前
【LeetCode】将 x 减到 0 的最小操作数
算法·leetcode
小羊失眠啦.9 小时前
用 Rust 实现高性能并发下载器:从原理到实战
开发语言·后端·rust