内存的存储及其存储方式

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;
}
posted @ 2023-02-11 02:37  燥zao  阅读(423)  评论(5编辑  收藏  举报