有没有内置的方法可以确保C++流中多字节类型的字节序?特别是,我想使用 read()
和 write()
向/从流中读取/写入小字符数组。我需要确保这些将始终以小端格式存储。(是的,我可以一次做一个字节或使用移位等,但这不是我的问题。
对于字符数组,您无需担心字节序,因为每个字符都是一个字节。如果要将整数之类的内容编码为一系列字节,则流不需要作为 char 数组进行读写,而是作为类型化数组进行读写,以便您知道自己在处理什么。也就是说,当您将整数转换为字节时,您已经丢失了恢复字节序所需的信息。
没有办法保证这一点。我很确定无论如何,这是由架构而不是编译器决定的。不过,有一些方法可以检查字节序。
在您的特定情况下,并没有真正的担忧,因为据我所知,C++存储的每个严肃实现都char
为单个字节。
移位就无法做到这一点 - 当您使用它时,该架构会强制您在内存中按特定顺序排列它们 - 最简单的解决方法是使用字节顺序标记。 如果这是不可接受的,恐怕你必须使用轮班。
为了检查你的假设是否正确,你可以说这样的话
static_assert(sizeof(char) == 1, "Chars are not one byte!!!!????");
对于字符数组,"其他人说了什么"。
对于更复杂的数据类型,与其滚动自己的数据类型,不如查看现有的序列化项目。在撰写本文时,谷歌的protobuf似乎不是一个糟糕的选择。
此函数可以简单地检查系统的字节序:
void print_endianness() {
union {
unsigned int i;
char c[4];
} un;
un.i = 0x12345678;
if (un.c[0] == 0x78 && un.c[3] == 0x12)
printf("little-endiann");
else if (un.c[0] == 0x12 && un.c[3] == 0x78)
printf("big-endiann");
else
printf("unknownn");
}