我需要一种快速的方法来获得float
具有给定位模式的 (提供为int32_t
)。当然,编译器应该优化整个构造。简单的转换会进行强制转换并且reinterpret_cast<>
不允许...
问问题
803 次
2 回答
5
编译器会优化它是不可靠的,但它避免了 UB,前提是提供的值确实是浮点数的表示(也就是说,它的大小正确,并且它的位模式不包含 的陷阱表示float
)。GCC 至少有时能够将其优化掉:
float convert(int32_t inputvalue) {
float f;
std::memcpy(&f, &inputvalue, sizeof(f));
return f;
}
如果优化是问题的重要部分,那么官方的回答是无法保证未知编译器会进行给定的优化。但是这个比大多数更难优化。它依赖于编译器“理解”做什么memcpy
,这比“理解”指针转换的作用更大。
于 2013-02-13T14:11:45.667 回答
2
唯一完全可移植的方法是memcpy
通过缓冲区:
static_assert(sizeof(float) == sizeof(int32_t), "!!");
char buf[sizeof(float)];
memcpy(buf, &i, sizeof(buf));
memcpy(&f, buf, sizeof(buf));
通常可以省略缓冲区:
static_assert(sizeof(float) == sizeof(int32_t), "!!");
memcpy(&f, &i, sizeof(float));
于 2013-02-13T14:14:11.313 回答