RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1583790
Accepted
Stanislav Volodarskiy
Stanislav Volodarskiy
Asked:2024-06-13 19:57:35 +0000 UTC2024-06-13 19:57:35 +0000 UTC 2024-06-13 19:57:35 +0000 UTC

在Java中打印实数的精确值

  • 772

数字12.000001不能完全以实际格式表示。存储的值为12.0000009999999992515995472786016762256622314453125。问题是如何用语言准确地打印出来呢?

我尝试了这些方法:

        double a = 12.000001;
        System.out.println("- " + a);
        System.out.println(String.format("%%f %f", a));
        System.out.println(String.format("%%.20f %.20f", a));
        System.out.println(String.format("%%.60f %.60f", a));
        System.out.println(String.format("%%g %g", a));
        System.out.println(String.format("%%.20g %.20g", a));
        System.out.println(String.format("%%.60g %.60g", a));

事实证明,准确打印是不可能的:

- 12.000001
%f 12.000001
%.20f 12.00000100000000000000
%.60f 12.000001000000000000000000000000000000000000000000000000000000
%g 12.0000
%.20g 12.000001000000000000
%.60g 12.0000010000000000000000000000000000000000000000000000000000

PS为什么需要这个?例如用于调试。或者编写代码来说明问题中的问题当比较两个实数时,我们得到不同的结果。

java
  • 1 1 个回答
  • 50 Views

1 个回答

  • Voted
  1. Best Answer
    Roman-Stop RU aggression in UA
    2024-06-14T01:14:28Z2024-06-14T01:14:28Z

    您可以使用BigDecimal:

    String.format("%%.51g %.51g", new BigDecimal(a))
    

    有趣的是,它“知道”float(23 位,即大约7 位小数)和 double(52 位,大约15 位小数String.format)中有效位的数量,并且不会显示不重要的位。

    12.0000009999999992515995472786016762256622314453125结果是15位数字12.0000010000000。事实证明,没有不必要的零12.000001。

    我们没有BigDecimal这个问题,因为...BigDecimal完整存储数字的所有数字,并且在初始化 from 的情况下,double对 中 表示的值进行精确转换,double而不进行四舍五入。

    以下是文档对此的说明BigDecimal(double):

    此构造函数的结果可能有些不可预测。人们可能会认为在 Java 中编写 new BigDecimal(0.1) 会创建一个完全等于 0.1 的 BigDecimal(未缩放的值 1,小数位数为 1),但它实际上等于 0.1000000000000000055511151231257827021181583404541015625。这是因为 0.1 不能精确地表示为 double(或者就此而言,表示为任何有限长度的二进制分数)。因此,无论表面如何,传递给构造函数的值并不完全等于 0.1。

    格式化时,您可以使用存储号码的所有可用数字。

    • 1

相关问题

  • wpcap 找不到指定的模块

  • 如何以编程方式从桌面应用程序打开 HTML 页面?

  • Android Studio 中的 R.java 文件在哪里?

  • HashMap 初始化

  • 如何使用 lambda 表达式通过增加与原点的距离来对点进行排序?

  • 最大化窗口时如何调整元素大小?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5