• 小端格式和大端格式


    本文转载自 清风行云:小端格式和大端格式(Little-Endian&Big-Endian)

     
     
    大端机和小端机
      不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序。
      最常见的有两种:
        1. Little-endian:将低序字节存储在起始地址(低位编址)
        2. Big-endian:将高序字节存储在起始地址(高位编址)
     

      小端机 LE(little-endian):
        最符合人的思维的字节序 
        地址低位存储值的低位,地址高位存储值的高位 
        怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说,低位值小,就应该放在内存地址小的地方,也即内存地址低位;反之,高位值就应该放在内存地址大的地方,也即内存地址高位 
     
     
      大端机 BE(big-endian): 
        最直观的字节序 
        地址低位存储值的高位,地址高位存储值的低位 
        为什么说直观,不要考虑对应关系,只需要把内存地址从左到右按照由低到高的顺序写出,把值按照通常的高位到低位的顺序写出,两者对照,一个字节一个字节的填充进去 

     
     
      实例
     
      例子1:在内存中双字0x01020304(DWORD)的存储方式。 
        内存地址 4000 4001 4002 4003
        LE      04   03   02   01 
        BE      01   02   03   04 
      注:每个地址存1个字节,每个字有4个字节。2位16进制数是1个字节(0xFF=11111111)。

     
      例子2:如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
            big-endian   little-endian
        0x0000    0x12         0xcd
        0x0001    0x23         0xab
        0x0002    0xab         0x34
        0x0003    0xcd         0x12

      x86系列的CPU都是little-endian的字节序。
  • 相关阅读:
    Debian / Ubuntu 更新内核并开启 TCP BBR 拥塞控制算法
    axios 常用的几个方法
    doT模板双重循环模板渲染方法
    利用闭包,在不设置全局变量的情况下,完成再次点击退出功能
    技术支持
    隐私政策
    apicloud踩坑集锦
    apicloud运行机制
    apcloud混合式开发app学习笔记
    bootstrap 弹出框 另类运用
  • 原文地址:https://www.cnblogs.com/freyr/p/4529813.html
Copyright © 2020-2023  润新知