我想切换浮点值和 double 值的“字节序”,它可以正常工作,方法如下:
float const v{1.f};
swap(reinterpret_cast<::std::uint32_t const&>(v));
是否存在更好的方法来进行交换,而无需强制转换?
编辑:swap()
是 gcc 内置函数的 C++ 包装器,我没有在此处包含它。
uint16_t __builtin_bswap16 (uint16_t x)
uint32_t __builtin_bswap32 (uint32_t x)
uint64_t __builtin_bswap64 (uint64_t x)
某些数据格式需要交换字节顺序,例如 CBOR。
最佳答案
虽然尝试避免强制转换是一种很好的做法,但正是这样的使用才是强制转换存在的原因。字节序交换是一种原始数据操作,因此为了做到这一点,您必须去掉键入信息,我想说,如果它一开始的字节序不正确,那么它就不是 float ,并且永远不应该以这种方式键入处于错误的字节序状态。
关于c++ - 交换 float 和 double 的 "endianness",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42558917/