zoukankan      html  css  js  c++  java
  • 如何使java中double类型不以科学计数法表示

    在java中,把一个double或者BigDecimal的小数转换为字符串时,经常会用科学计数法表示,而我们一般不想使用科学计数法,可以通过:
    DecimalFormat a = new DecimalFormat("#,##0.00000000");
            System.out.println(a.format(11111111.0000001000000001));
    的方式来格式化输出字符串。

    对于BigDecimal的小数,如果制定精度<=6, 则可以放心的使用其toString函数。但是对于>6的精度,有可能会使用科学计数法,查看器代码有如下判断:
    long adjusted = -(long)scale + (coeff.length-1);
            if ((scale >= 0) && (adjusted >= -6)){
                      非科学计数法的toString.
            }
    其中scale指BigDecimal的精度,
    coeff对应使用BigInteger存储的值的toString字符串, coeff = intVal.abs().toString().toCharArray(),也就是说BigDecimal在对应精度下的整数值,例如BigDecimal ob = new BigDecimal(0.00000011), ob的精度为7, 则coeff="1";如果ob=new BigDecimal(0.10000011), 则coeff="1000001";如果ob=new BigDecimal(0.00000001), 则coeff="0";

    多使用bigdecimal  少使用double

  • 相关阅读:
    (2/24) 快速上手一个webpack的demo
    (1/24) 认识webpack
    module.exports 、exports、export、export default的区别
    Git同时提交到多个远程仓库
    @codeforces
    @loj
    @bzoj
    @loj
    @bzoj
    @bzoj
  • 原文地址:https://www.cnblogs.com/toSeeMyDream/p/5539385.html
Copyright © 2011-2022 走看看