zoukankan      html  css  js  c++  java
  • android如何保留小数点后x位数字

    主要可以采用BigDecimal这个东西,我是使用了decimal成功解决了问题

     

    1:

    (double)(Math.round(result_value*10000)/10000.0)  

     

    这样计算可以保留result_value小数点后四位,以此类推,1后面几个零就是保留小数点后几位数. 

     

     

    2:

     import java.text.DecimalFormat;  

    DecimalFormat df = new DecimalFormat("##0.00");  

    System.out.println(df.format(double_value));  

     

    这样就是保留小数点后两位小数,如果想保留三位,则为 

     

    DecimalFormat df = new DecimalFormat("##0.000");  

     

     

    还推荐有四种方法

    Long是长整型,怎么有小数,是double吧

    java.text.DecimalFormat df=new java.text.DecimalFormat("#.##");

    double d=3.14159;

    System.out.println(df.format(d));

    java.math.BigDecimal

    BigDecimal bd = new BigDecimal("3.14159265");

    bd = bd.setScale(2,BigDecimal.ROUND_HALF_UP);  

    这里面的bd是自定义的变量,即最后取得小数点后若干位的数,2表示小数点后两位

    class Test1{

    public static void main(String[] args){

    double ret = convert(3.14159);

     

    System.out.println(ret);

    }

     

    static double convert(double value){

    long l1 = Math.round(value*100); //四舍五入

    double ret = l1/100.0; //注意:使用 100.0 而不是 100

    return ret;

    }

    }

    double d = 13.4324;

    d=((int)(d*100))/100;  

     

     

    第二种方法最好

    Related posts:

  • 相关阅读:
    [转] Oracle数据库备份与恢复
    Oracle RMAN 恢复控制文件到指定的路径
    [转] AIX lv 4k偏移量
    关于oracle 10g creating datafile with zero offset for aix
    linux中的chage命令
    [转] Oracle sql 查询突然变慢 -- 案例分析
    [转] Oracle analyze table 使用总结
    [转] Oracle analyze 命令分析
    .net 事务
    _BIN 二进制排序
  • 原文地址:https://www.cnblogs.com/zhoujian315/p/3176812.html
Copyright © 2011-2022 走看看