如何在C++中获得给定位模式(如int32_t)的浮点值
How to get the float with given bit-pattern (as int32_t) in C++?
我需要一种快速的方法来获得具有给定比特模式的float
(作为int32_t
提供)。当然,编译器应该优化整个结构。简单转换进行强制转换,不允许使用reinterpret_cast<>
。。。
编译器将对此进行优化是不可靠的,但它可以避免UB,前提是提供的值确实是浮点的表示(即,它的大小合适,并且其位模式不包含float
的陷阱表示)。GCC至少有时能够优化它:
float convert(int32_t inputvalue) {
float f;
std::memcpy(&f, &inputvalue, sizeof(f));
return f;
}
如果优化是问题的重要组成部分,那么官方答案是无法保证未知编译器会进行给定的优化。但这个比大多数更难优化。它依赖于编译器"理解"memcpy
的作用,这比"理解"指针强制转换的作用更重要。
唯一完全可移植的方法是通过缓冲区到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));
相关文章:
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 为什么在保护模式下继承升级不起作用
- 如何在全屏模式下(在OpenGL中)使背景透明
- 为什么使用__LINE_的代码在发布模式下在MSVC下编译,而不是在调试模式下
- 派生类是否可以在抽象工厂设计模式中具有数据成员
- 此模式的C++RegEx
- avrogencpp能为模式中的每种类型生成单独的头文件吗
- 使用可变模板的Broadcaster/Listener模式
- c++方法参数只能在linux的发布模式下自行更改
- 资源管理设计模式
- 使用 mod_gsoap 部署服务时,如何在 Gsoap 中更改 soap 上下文的模式?
- C++ 无法在字符数组中使用 for 循环打印字母模式
- 小字符串优化(调试与发布模式)
- 可视化C++:发布模式的运行时库作为'Multi-threaded Debug DLL'
- 如何设计具有不同类型的通知和观察器的观察者模式?
- 在C++的一系列数字中查找重复模式
- 是否允许使用带有"w+"模式的 freopen 进行标准设置?
- C++ 使用存储在动态数组中的文本文件中的数据查找模式
- С++ wxWidgets:代码架构,设计原则和模式
- 以只读模式打开数据库时SQLITE_CANTOPEN错误