C++20 字节序 endian¶
在面试的时候,字节序通常是一个非常重要的考点,会考察:
- 大小端概念
- 如何判断大小端
- 主机字节序
- 网络字节序
- 等等
,那么判别方式其实有很多种,例如:
- C++20的endian
- union
- 地址转换
- htons
那么本节就来阐述一下C++20的大小端使用与基础知识。
注:懒人版,4种方式判别大小端源码已放星球,感兴趣获取即可。
1.字节序基础¶
系统的字节序指的是字节在内存中存储或通过网络传输的顺序。大端系统在最低内存地址存储最高有效字节(MSB)。这在各种网络协议中用于通过网络发送数据,也称为网络字节序。在小端系统中,最低有效字节(LSB)存储在最低内存地址。例如,十六进制数0x12345678的存储方式如下:
- 大端:
- 小端
根据架构的不同,不同的系统可能是大端或小端的主机字节序。
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;
}
}