- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我在 C 中有这段代码,我将 0.1 声明为 double 。
#include <stdio.h>
int main() {
double a = 0.1;
printf("a is %0.56f\n", a);
return 0;
}
这是它打印的内容,a 是 0.10000000000000001000000000000000000000000000000000000000
C++ 中的相同代码,
#include <iostream>
using namespace std;
int main() {
double a = 0.1;
printf("a is %0.56f\n", a);
return 0;
}
这是打印出来的,a 是 0.1000000000000000055511151231257827021181583404541015625
有什么区别?当我读取两者时都分配了 8 个字节? C++如何在小数位上打印更多的数字?
另外,它怎么能到小数点后 55 位? IEEE 754 浮点只有 52 位小数,我们可以得到 15 位小数的精度。它以二进制形式存储。它的十进制解释如何存储更多?
最佳答案
使用 MinGW g++(和 gcc)7.3.0,您的结果可以准确再现。
这是一个非常奇怪的未定义行为案例。
未定义的行为是由于使用了 printf
不包括适当的标题,¹违反“应”在
” A translation unit shall include a header only outside of any declaration or definition, and shall include the header lexically before the first reference in that translation unit to any of the entities declared in that header. No diagnostic is required.
在 C++ 代码更改 <iostream>
至<stdio.h>
, 以获取有效的 C++ 代码,您将获得与 C 程序相同的结果。
为什么 C++ 代码甚至可以编译?
嗯,与 C 不同,在 C++ 中,允许将标准库头文件拖入任何其他头文件。显然使用 g++ 的 <iostream>
标题拖入 printf
的一些声明.只是不完全正确。
详细信息:在 MinGW g++ 7.3.0 中,printf
的声明/定义取决于宏符号 __USE_MINGW_ANSI_STDIO
。默认就是 <stdio.h>
声明 printf
.但是当__USE_MINGW_ANSI_STDIO
被定义为逻辑真,<stdio.h>
提供 printf
的最重要定义, 调用 __mingw_vprintf
.碰巧<cstdio>
header 定义(通过间接包含)__USE_MINGW_ANSI_STDIO
在包括 <stdio.h>
之前.
<_mingw.h>
中有评论, "请注意,我们也为 C++ 中的 _GNU_SOURCE 启用它,但不适用于 C 情况。"。
在 C++ 中,使用此编译器的相关版本,包含 <stdio.h>
之间实际上存在差异。并使用 printf
, 或包括 <cstdio>
,说using std::printf;
, 并使用 printf
.
关于
” Also, how can it go until 55 decimal places? IEEE 754 floating point has only 52 bits for fractional number with which we can get 15 decimal digits of precision. It is stored in binary. How come its decimal interpretation stores more?
...只是十进制的表示更长。超出内部表示精度的数字(对于 64 位 IEEE 754 大约为 15 位)本质上是垃圾,但它们可以用来精确地重构原始位。在某些时候,它们将变为全零,并且 C++ 程序输出中的最后一位达到该点。
1感谢Dietrich Epp用于查找该标准报价。
关于c++ - 为什么 C 中的 double 打印的十进制数字比 C++ 少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52660296/
下面的代码有效,我觉得double(double)和double(*)(double)没有区别,square和 &square,我说得对吗? #include double square(doubl
我知道我的作业很草率,这是我在这门课上的第 4 次作业。任何帮助将不胜感激,谢谢。 double getPrincipal(0); double getRate(0); double getYe
我遇到了那个错误,当我使用类时,我在使用函数指针时遇到了这个错误。我的函数'ope'函数我该如何解决 evaluator::function(){ double (*ope) (dou
问题://故事从哪里开始 Graphics 类型中的方法 drawLine(int, int, int, int) 不适用于参数 (double, double, double, double) g.
我有一张 map> m1 形式的 map .我可以将其复制到 map m2 形式的 map 吗?这样键是相同的,并且 m2 中的值是 get(m1->second) 不使用循环?谢谢! 最佳答案 这样
有没有办法获取vector> 的“.first”和“.second”的连续内存? ?我的意思是: void func(int N, double* x, double* y) { for (i
我正在尝试将自定义 lambda 传递给需要函数指针的函数(更准确地说是 zero 中的 Brent library 函数)。 我的想法是,我将使用参数创建一次 lambda,然后用多个值对其求值 x
这是一个很简单的问题,让我很困惑。 我收到一个源文件的以下错误,但另一个没有: 4 src/Source2.cpp:1466: error: no matching function for cal
struct CalculatorBrain { private var accumulator: Double? func changeSign(operand: Double) -
在我正在进行的项目中,我尝试使用 curlpp库来发出一个简单的 html GET 请求。当我将 cpp 文件传递给 g++ 时,出现以下错误: /usr/local/include/curlpp
不使用double就能获得quadruple精度超过16位的数字吗?如果可能的话,这取决于编译器还是其他?因为我知道有人说他使用double精度,并且具有22位精度。 最佳答案 数据类型double
我正在寻找有关特斯拉 GPU 中硬件如何实现 double 的信息。我读到,两个流处理器正在处理单个 double 值,但我没有找到 nvidia 的任何官方论文。 提前致谢。聚苯硫醚为什么大多数 G
这个问题在这里已经有了答案: Passing capturing lambda as function pointer (10 个答案) 关闭 2 年前。 我有这个错误 error: cannot
情况:我有一个元组列表,其中添加了一个元组: List> list = new List>(); list .Add(new Tuple(2.2, 6.6)); 一切似乎都还好。但是......在 D
我有一个 JList,里面有一堆名字,还有一个包含这些名字值的数组 final Double[] filmcost = { 5.00, 5.50, 7.00, 6.00, 5.00 }; 我想做的是,
我试图找出牛顿法来求方程的根。这个错误出来了,我无法处理。 double fn(double n){ return sin(n)+log(n)-1; } double f1n(double n
我有一个 junit 测试断言两个 Double 对象,具有以下内容: Assert.assertEquals(Double expected, Double result); 这很好,然后我决定将其
我正在尝试引入部分数据文件来填充数组,用户尝试了三次输入正确的数据文件名。我一再遇到这些错误。我知道像 arr 这样的数组只是一个指向内存块的指针。 #include #include #incl
我正在尝试完成复习题(为即将到来的编程决赛),但是,我无法解决这个问题,因为我不断收到错误(标题)。正如预期的那样,我将发布问题和我尝试的解决方案。 问题: 给定以下函数定义:void swap(do
任何人都知道如何实现这一目标。我已经尝试了通常的公式,但我只得到正数 Double.NEGATIVE_INFINITY) return d; } } 这将以相同的概率
我是一名优秀的程序员,十分优秀!