C++-对浮点值中的位进行操作
C++ - Operating on the bits in a floating point value
我正试图编写一个函数,将一组字节重新解释为float
。我看过一个Stackoverflow问题,这个问题让我在一个字符数组上尝试reinterpret_cast<>()
,我开始尝试将浮点值拆分为字符,然后再次重新组合,但这只会给我带来看似随机的数字,而不是我认为的值,因为每次的输出都不一样。几个不同的例子是:
1.58661e-038
3.63242e-038
2.53418e-038
浮点变量应该包含值5.2。
编译代码:
float f = 5.2;
unsigned char* bytes = reinterpret_cast<unsigned char*>(&f);
float f1 = reinterpret_cast<float&>(bytes);
std::cout << f1 << std::endl;
给了我
1.75384e-038
当然,每次运行程序时都会有一个不同的数字。然而,有趣的是,如果我把代码放在一个循环中,并在一次运行中执行几次,输出就会保持一致。这让我认为它可能是一个内存位置,但如果是这样,我不确定如何访问变量的实际值——解引用运算符不起作用,因为它不是指针。
因此,我的问题是——我如何将类型为float
的变量(以及后来的double
)拆分为单独的字节(允许我修改比特),然后重新组装它
如有任何帮助,我们将不胜感激。
bytes
是指针。
更改
float f1 = reinterpret_cast<float&>(bytes);
至
float f1 = *reinterpret_cast<float*>(bytes);
// Cast to a different pointer... ^
// ^ ...and dereference that pointer.
相关文章:
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 重载操作程序时出错>>用于类中的字符串 memebr
- 对字符串进行位操作
- 我可以在 C++ 中的函数体之外进行操作吗?
- MPI突然停止了对多个核心的操作
- 如何在信号处理程序和普通函数中对全局变量进行互斥读写操作
- 对字符数组中的元素执行逐位操作
- 如何在directx/c++中进行平移/缩放操作
- 逐位操作的隐式类型转换
- 为什么一个向量上的多线程操作很慢
- 排序时无法执行交换操作.我做的时候它会崩溃.为什么
- 位移操作和位掩码未检测到重复字符
- 如何进行特定的位操作?
- 当我们进行一些操作时,应该使用什么'std::string'或'std::stringstream'?
- 字符串操作 - 字符计数
- 此代码中的操作流程是什么?C/C++.
- 复制和交换习惯用法与移动操作之间的交互
- 像union_这样的 Boost.Geometry 操作如何处理浮点类型的基本不精确性?
- 为什么 std::lerp 不适用于任何已实现所需操作的类型?
- 无法合并生成操作.. 先决条件不同