我有一些(遗留嵌入式 c)代码通过一些 sprintf
调用生成 .csv 文件。偶尔我会看到 1.#QO
的值。我已经尝试在应该给出负无穷大、正无穷大和 NaN 的条件下重现这些值,但它们似乎都没有给我神奇的 1.#QO
结果。那么产生这种值(value)的是什么?
...是的,我知道产生该值的数学运算显然出了问题,但理解它的含义将有助于调试工作。
[编辑 1] 进行转换的实际行是:
sprintf_s(txt, CSV_HEADER_SIZE, "%.3f", value);
哪里:
#define CSV_HEADER_SIZE (100)
char txt[CSV_HEADER_SIZE];
我正在使用 MS Visual Studio 2008 进行编译。
[编辑 2] 进一步挖掘显示 0xFFFFFFFF
给出 -1.#QO
:
unsigned int i = 0xFFFFFFFF;
float* f = (float*)&i;
printf("%.3f", *f); // gives -1.#QO
..并在 Visual Studio 调试器中查看它,将其扩展为 -1.#QNAN00
所以看起来这可能是 NaN
的 Microsoft 特定表示?
最佳答案
“-1.#QO”在小数点后“四舍五入”后为“-1.#QNAN”。 N 舍入为 O,如 'A' >= '5' 和 'N' + 1 == 'O'。
这与您的调试器显示“-1.#QNAN00”的原因类似,因为它打印了 7 个位置并在末尾添加了填充零。
QNaN 是 quiet NaN .
关于c - 什么浮点值使 sprintf_s() 产生 "1.#QO"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5939573/