大小端的最简单记法
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
所以给你看张图你基本就懂了
至于有关字地址和字节地址和寻址的几大题型,请看其他的博客