[英]C++ - Operating on the bits in a floating point value
我正在尝试编写一个将一组字节重新解释为float
的函数。 我已经看过一个Stackoverflow问题 ,这使我尝试对字符数组进行reinterpret_cast<>()
的工作,然后我开始尝试将一个float拆分为char,然后再次对其进行重新组装,但这只是给我看似随机数而不是我的数字认为值应该是,因为每次输出都不同。 一些不同的示例是:
1.58661e-038
3.63242e-038
2.53418e-038
float变量应包含值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.
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.