计算机组成原理中大小端的区别

大小端的最简单记法

1.只需要记住——大端就是正常人的思维就可以了。比如说你有12345678要存在一个存储单元里面,那你肯定想的就是像下面这样存储嘛

内存地址 存储内容
0x4000 12
0x4001 34
0x4002 56
0x4003 78

然后你再记住大的和小的相反就可以了。

具体讲解

1.你首先需要明白一个显而易见的事实——数据本身是有高低位的
比如说十进制的987,那9肯定就是高位啊(百位比十位高),7就是低位嘛。而对于数字12345678而言,1就是高位而8就是低位
如果实在不能理解这一点,可以去mooc学一下小学一年级下的内容
2.还有一个事实就是——无论什么机器什么配置,内存地址都是有序增加的比如说从0000-0001-0002-0003依次增加。既不会存在0000-0003-0002-0001这样诡异的情况,也不会存在0004-0003-0002-0001-0000这样的情况(具体的原因挺复杂的,大概理解成便于扩充和避免采取补码带来的麻烦吧)
3.所谓的大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放。
4.所谓的小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。

我知道看了上面两段话你肯定觉得讲的是个xx

所以给你看张图你基本就懂了
在这里插入图片描述
至于有关字地址和字节地址和寻址的几大题型,请看其他的博客

猜你喜欢

转载自blog.csdn.net/weixin_43914889/article/details/87859661