字节序,大小端问题

我们都知道一个字节等于8个比特,而一个比特只能存放一个0或者一个1,因此一个字节最大能存储的数字为 11111111(255)。那么当我们要存储 65530 这种需要多字节内容时,就会出现两种情况:

内存中的多字节数据相对于内存地址有大端和小端之分。

  • 大端字节序:高地址存低位
  • 小端字节序:低地址存低位

假设我们要将0x1234abcd存入以0x0000开头的内存中,

big-endian大端 little-endian 小端
0x0000 0x12 0xcd
0x0001 0x34 0xab
0x0002 0xab 0x34
0x0003 0xcd 0x12

为什么会有大端字节序和小端字节序?

  • 计算机电路处理低字节序,效率比较高,因为计算都是从低位开始的
  • 人类习惯读写大端字节序,所以除了计算机内存处理,其他场合几乎都是大端字节序,比如:网络传输和文件存储。

如何判断电脑是大端还是小端?

int main()
{
    int a = 1;
    if( 1== ((char *)&a)[0]){
        printf("小端字节序\n");
    }
    else if( 0== ((char *)&a)[0]){
        printf("大端字节序\n");
    }
    return 0;
}
全部评论

相关推荐

每晚夜里独自颤抖:要求太多的没必要理
点赞 评论 收藏
分享
门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务