C++20那些事之一文打通字节序

C++20那些事之一文打通字节序

大纲:

  • 1.字节序基础

  • 2.字节序的重要性

  • 3.检查字节序

在面试的时候,字节序通常是一个非常重要的考点,会考察:

  • 大小端概念

  • 如何判断大小端

  • 主机字节序

  • 网络字节序

  • 等等

,那么判别方式其实有很多种,例如:

  • C++20的endian

  • union

  • 地址转换

  • htons

那么本节就来阐述一下C++20的大小端使用与基础知识。

注:懒人版,4种方式判别大小端源码已放星球,感兴趣获取即可。

1.字节序基础

系统的字节序指的是字节在内存中存储或通过网络传输的顺序。大端系统在最低内存地址存储最高有效字节(MSB)。这在各种网络协议中用于通过网络发送数据,也称为网络字节序。在小端系统中,最低有效字节(LSB)存储在最低内存地址。例如,十六进制数0x12345678的存储方式如下:

  • 大端:

地址     | 值

n       | 0x12
n + 1   | 0x34
n + 2   | 0x56
n + 3   | 0x78
  • 小端

地址    | 值

n       | 0x78
n + 1   | 0x56
n + 2   | 0x34
n + 3   | 0x12

根据架构的不同,不同的系统可能是大端或小端的主机字节序。

2.字节序的重要性

那么,这为什么重要呢?如果你需要通过网络发送数据,那么你需要确保它以网络字节序传输。在大多数情况下,你的主机字节序将是小端,这意味着你需要在传输数据之前反转字节的顺序。

3.检查字节序

C++20引入了一种更简单且更可移植的方式来检查字节序,即std::endian。你可以使用std::endian::native检查系统的主机字节序。下面是一个简单的例子:

void checkEndianness() {
  if constexpr (std::endian::native == std::endian::little) {
    std::cout << "小端" << std::endl;
  } else if constexpr (std::endian::native == std::endian::big) {
    std::cout << "大端" << std::endl;
  } else {
    std::cout << "未知" << std::endl;
  }
}

揭秘答案,戳下方呀~

be2fce97166219503a23fed05ed68258.jpeg

往期推荐:

向量数据库milvus源码剖析之开篇

热度更新,手把手实现工业级线程池

dff72f3c56880a847388e4d632a14e83.jpeg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值