关于C++内存生长

这篇博客探讨了C++中内存分配的情况,通过一个简单的示例展示了结构体与整型变量在内存中的布局。作者注意到结构体与整型变量之间存在4字节的间隔,并且结构体总是位于每16字节对齐的地址。在GDB调试中,观察到Windows环境下内存是从高地址向低地址生长,并且每个变量前后有4字节的填充值。作者对于这些编译器行为的目的感到好奇,期待有经验的读者分享见解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天看到网上帖子说计算机中内存的生长的方式是从高地址到低地址的,很久以前就了解过这个知识点,但还是不禁写了个代码试了一下。这一试发现了更多问题。

测试代码如下:
​​​

#include <stdio.h>

struct TestType

{

    int _a; 

    int _b; 

};

int main()

{

    int a = 1;

    struct TestType testa;

    int b = 4;

    testa._a = 2;

    testa._b = 3;

    int c1 = 5, c2 = 6, c3 = 7;

    int d[10];

    printf("a = %p,\n", &a);

    printf("testa = %p,\n", &testa);

    printf("b = %p,\n", &b);

    printf("c1 = %p, c2 = %p, c3 = %p,\n", &c1, &c2, &c3);

    printf("d[0] = %p, d[2] = %p\n", &d[0], &(d[2]));

    return 0;

}

GDB调试结果如下:

​​


这个结构体和int变量中间多了4字节的奇怪玩意儿,不晓得是神马鬼,然后调整了struct定义的位置,发现每次struct变量出现的位置总是在每16个字节的开始位置。比如说例子中的testa前面这样定义的话:

int a;

int b;

TestType testa;

那么testa的分布就会变成这样:

a = 0x7fff54ac4be8,
b = 0x7fff54ac4be4,
testa = 0x7fff54ac4bd0,

还没搞明白为什么。(测试环境:macos x 10.10.4,gcc版本4.9.2)


然后又去VS下测试了一下,发现windows下确实是高地址向低地址顺序生长的,但是VS下也有奇怪的现象,每个变量的开始和结束都会有4字节的cc值,不知道是干什么的。


这些应该都是编译器的设计,但是不太了解这样的意图,如果有高人知道以上两点,希望能给予指导,不胜感激!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值