打印内存地址

时间:2013-12-22 13:48:00

标签: c++

我在Windows8上的Cygwin上运行了以下程序。

#include<iostream>
#include <stdio.h>
using namespace std;
int main(){
char c1 = 'a';
char c2 = 'b';
int i1 = 1;
float l1 = 100;
float f1 = 3.14;
double d1 = 1.424;
int i2;
char c3;
int i3;
printf("&c1 -> %u\n", (unsigned long)&c1);
printf("&c2 -> %u\n", (unsigned long)&c2);
printf("&i1 -> %u\n", (unsigned long)&i1);
printf("&l1 -> %u\n", (unsigned long)&l1);
printf("&f1 -> %u\n", (unsigned long)&f1);
printf("&d1 -> %u\n", (unsigned long)&d1);
printf("&i2 -> %u\n", (unsigned long)&i2);
printf("&c3 -> %u\n", (unsigned long)&c3);
printf("&i3 -> %u\n", (unsigned long)&i3);
}

我的笔记本电脑给出了以下结果。

$ ./a.exe
&c1 -> 2337487
&c2 -> 2337486
&i1 -> 2337480
&l1 -> 2337476
&f1 -> 2337472
&d1 -> 2337464
&i2 -> 2337460
&c3 -> 2337459
&i3 -> 2337452

据我所知,每种数据类型都有自己的大小,并根据大小占用内存地址。例如,在这种情况下,由于char类型只有1个字节大小,变量c1占用1个内存地址(2337487),下一个变量c2从地址2337486开始但是,我对i1从2337480开始感到困惑。如果c2也是char类型变量,它不应该只占用一个地址吗? i1从2337485开始?

我想这与编译器有关,但不明白它是如何工作的。有人会给我一些建议吗?

2 个答案:

答案 0 :(得分:2)

这是因为数据结构对齐。

例如,当计算机的字大小为4个字节(一个字节在大多数机器上意味着8位,但在某些系统上可能不同)时,要读取的数据应该是内存偏移量,这是4的倍数如果不是这种情况,例如数据从第14个字节而不是第16个字节开始,然后计算机必须读取两个4字节的块并在读取所请求的数据之前进行一些计算,否则它可能会产生对齐错误。即使先前的数据结构在第13个字节结束,下一个数据结构应该从第16个字节开始。在两个数据结构之间插入两个填充字节,以将下一个数据结构与第16个字节对齐。

答案 1 :(得分:-1)

这是一个编译器优化:当分配的内存不是固定块时,它会更快。