大小端存储的理解

来源:互联网 发布:阿里云是paas 编辑:程序博客网 时间:2024/06/05 03:47

在计算机内存中的数据存储的都是机器二进制序列,在学习c/c++语言的时候会定义到一些变量,比如

int(整形)、char(字符型).....但是在计算机中是怎样存储的呢?

计算机的内存地址是有高低之分的,那么一个整形数在内存中占有四个字节它又是怎样存储的呢?是低

位放在低地址,还是低位放在高地址?在这里我们可以通过一个小小的c程序来进行验证一下:

#include<stdio.h>#include<stdlib.h>int main(){ int a=1; char *p = NULL; p = (char*)&a; printf("%x\n", *p); system("pause"); return 0;

运行结果是 1
首先来看一下计算机中是怎样存储1这个数的,1的二进制序列是00000000 00000000 00000000 00000001
假设计算机给这个整形数1分配的四个字节的内存空间是0-3,而这个程序打印的内容是最低地址上的内

容,结果是1,所以可以得出以下结论:
        内存地址   0        1        2        3
 内存内容00000001 00000000 00000000 00000000
或者举一个十六进制数的例子  假如定义的这个数是 0x11223344,那么结果便是这样的:
        内存地址   0        1        2        3
 内存内容  44        33       33       11
也就是低位是存在低地址里边的,这种模式就是计算机的小端存储模式。
相反如果结果是另一种情况:
 内存地址   0        1        2        3
 内存内容00000000 00000000 00000000 00000001
或者是十六进制数
 内存地址   0        1        2        3
 内存内容  11        22       33       44
这种模式就是另一种存储模式,称为大端存储

0 0
原创粉丝点击