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;
}
}
揭秘答案,戳下方呀~
往期推荐: