确保 c++ 流中的字节序

Ensuring endianness in c++ streams

本文关键字:字节 c++ 确保      更新时间:2023-10-16

有没有内置的方法可以确保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");
}