内存的存储及其存储方式
1. 内存存储
2. 内存存储的方式
3.为什么要有大小端模式的区分
4.判断大小端模式
1.内存的存储:内存是由低地址向高地址进行存储。(即我们个位数为低地址位,而百,千位为高地址数)
为方便理解我们定义了一个变量a,如下
vs上方窗口栏:调试-->窗口-->内存-->内存1
在地址处输入&a,取a的地址
内存存储总结:我们可以看到数据是从左往右,即低地址往高地址走
2. 内存存储的方式:内存存储的两种方式分别为大端存储模式和小端存储模式,其概念如下:
大端模式的定义:是指数据的低位保存在内存的高地址中,而数据的高位,保存在数据的低地址中。
小端模式的定义:是指数据的低位保存在内存的低地址中,而数据的高位,保存在数据的高地址中。
大小端存储理解方式如下图:
3.为什么会有大小端的区分
这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,
一个字节为8bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32
bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者
32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排
的问题。因此就导致了大端存储模式和小端存储模式。
4.判断存储模式为大小端
可通过如下得知存储模式为大端还是小端:
int main(){
int a=1;
char*p=(char*)&a;
if(*p==1){
printf("小端\n");
}
else{
printf("大端\n");
}
return 0;
}