/**
     * 提供精确的乘法运算。
     * @param v1 被乘数
     * @param v2 乘数
     * @return 两个参数的积
     */
    public static double mul(double v1,double v2){
        BigDecimal b1 = new BigDecimal(Double.toString(v1));
        BigDecimal b2 = new BigDecimal(Double.toString(v2));
        return b1.multiply(b2).doubleValue();
    }运行 mul(12,0.6);
结果:12.0我不想要这个小数位的0怎么解决,有小数时就显示实际小数位数,而不要补0,
如果没有小数就直接显示整数

解决方案 »

  1.   

    new BigDecimal("12.0").setScale(0);
      

  2.   

    public static void main(String[] args) {        BigDecimal b = new BigDecimal("12.0");        System.out.println(b.setScale(0));
            System.out.println(b.stripTrailingZeros());
        }
      

  3.   

    有小数时就显示实际小数位数,而不要补0, 
    如果没有小数就直接显示整数==》刚才没看见这两句用  System.out.println(b.stripTrailingZeros()); 吧
      

  4.   

     /** 
        * 提供精确的乘法运算。 
        * @param v1 被乘数 
        * @param v2 乘数 
        * @return 两个参数的积 
        */ 
        public static double mul(double v1,double v2){ 
            BigDecimal b1 = new BigDecimal(Double.toString(v1)); 
            BigDecimal b2 = new BigDecimal(Double.toString(v2)); 
            return b1.multiply(b2).stripTrailingZeros().doubleValue(); 
        }
      

  5.   

    .doubleValue(); 之后会有.0,这个打印的时候根据需要自己处理一下就行了
      

  6.   

    /** 
        * 提供精确的乘法运算。 
        * @param v1 被乘数 
        * @param v2 乘数 
        * @return 两个参数的积 
        */ 
        public static String mul(double v1,double v2){ 
            BigDecimal b1 = new BigDecimal(Double.toString(v1)); 
            BigDecimal b2 = new BigDecimal(Double.toString(v2)); 
            return b1.multiply(b2).stripTrailingZeros()+“”; 
        } 
      

  7.   

    运行 mul(12,0.6);
    结果:12.0 12*0.6不等于12.0啊!
      

  8.   


    import java.math.BigDecimal;
    import java.text.DecimalFormat;public class Test { public static void main(String[] args) {
    String result = new DecimalFormat("#.##########").format(mul(12,0.06));
    System.out.println(result);
    result = new DecimalFormat("#.##########").format(mul(12,60));
    System.out.println(result);
    } public static double mul(double v1, double v2) {
    BigDecimal b1 = new BigDecimal(Double.toString(v1));
    BigDecimal b2 = new BigDecimal(Double.toString(v2));
    return b1.multiply(b2).doubleValue();
    }}
      

  9.   

    楼上的答案是错的;result = new DecimalFormat("#.##########").format(mul(12,0.000000000000000000180));打印结果为:
    0
      

  10.   

    System.out.println(Integer.PaseInt(mul(12,0.6)));
      

  11.   


    这个我试过了,可以的呀!import java.math.BigDecimal;public class RebBlueBoll { /**
     * @param args
     */
    public static void main(String[] args) {

    System.out.println(mul(12.0,1.0));
    System.out.println(mul(12.0,.6)); } public static String mul(double v1,double v2){ 
            BigDecimal b1 = new BigDecimal(Double.toString(v1)); 
            BigDecimal b2 = new BigDecimal(Double.toString(v2)); 
            return b1.multiply(b2).stripTrailingZeros()+""; 
        } 
    }
      

  12.   

    要如此吹毛求疵那没办法,可以这样:
    result = new DecimalFormat("#.##############################################################################################################################").format(mul(12,0.000000000000000000180));
    System.out.println(result);
      

  13.   

    要如此吹毛求疵那没办法,可以这样
    result = new DecimalFormat("#.###################################################################################").format(mul(12,0.000000000000000000180));
    System.out.println(result);
      

  14.   

    格式化输出数字翻译:Cherami
    email:[email protected]
    原文:http://developer.java.sun.com/developer/TechTips/2000/tt0411.html
     
          
    有时我们需要控制输出的数字的格式,如何使用java的类库做到这个呢?
    也许你不关心格式,但是你需要关心你的程序可以在全世界通用,像下面的这样一个简单的语句是依赖地区的:
        System.out.println(1234.56);
    在美国,"." 是小数点,但在其它地方就不一定了。如何处理这个呢?
    java.text 包中的一些包可以处理这类问题。下面的简单范例使用那些类解决上面提出的问题:
        
    import java.text.NumberFormat;
        import java.util.Locale;
        public class DecimalFormat1 {
            public static void main(String args[]) {
                // 得到本地的缺省格式
                NumberFormat nf1 = NumberFormat.getInstance();
                System.out.println(nf1.format(1234.56));
                // 得到德国的格式
                NumberFormat nf2 =
                    NumberFormat.getInstance(Locale.GERMAN);
                System.out.println(nf2.format(1234.56));
            }
        }如果你在美国,运行程序后输出:
        1,234.56
        1.234,56
    换句话说,在不同的地方使用不同的习惯表示数字。
    NumberFormat.getInstance()方法返回NumberFormat的一个实例(实际上是NumberFormat具体的一个子类,例如DecimalFormat), 这适合根据本地设置格式化一个数字。你也可以使用非缺省的地区设置,例如德国。然后格式化方法根据特定的地区规则格式化数字。这个程序也可以使用一个简单的形式:
        NumberFormat.getInstance().format(1234.56)
    但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。
    另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:
       
      import java.text.DecimalFormat;
        import java.util.Locale;
        public class DecimalFormat2 {
            public static void main(String args[]) {
                // 得到本地的缺省格式
                DecimalFormat df1 = new DecimalFormat("####.000");
                System.out.println(df1.format(1234.56));
                // 得到德国的格式
                Locale.setDefault(Locale.GERMAN);
                DecimalFormat df2 = new DecimalFormat("####.000");
                System.out.println(df2.format(1234.56));
            }
        }在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:
        1234.560
        1234,560
    相似的,也可以控制指数形式的格式,例如:
        
    import java.text.DecimalFormat;
        public class DecimalFormat3 {
            public static void main(String args[]) {
                DecimalFormat df = new DecimalFormat("0.000E0000");
                System.out.println(df.format(1234.56));
            }
        }输出:
        1.235E0003
    对于百分数:
        
    import java.text.NumberFormat;
        public class DecimalFormat4 {
            public static void main(String args[]) {
                NumberFormat nf = NumberFormat.getPercentInstance();
                System.out.println(nf.format(0.47));
            }
        }输出:
        47%
    至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在NumberFormat中。例如:
       
      import java.util.Locale;
        import java.text.NumberFormat;
        import java.text.ParseException;
        public class DecimalFormat5 {
            public static void main(String args[]) {
                // 本地格式
                NumberFormat nf1 = NumberFormat.getInstance();
                Object obj1 = null;
                // 基于格式的解析
                try {
                    obj1 = nf1.parse("1234,56");
                }
                catch (ParseException e1) {
                    System.err.println(e1);
                }
                System.out.println(obj1);
                // 德国格式
                NumberFormat nf2 =
                    NumberFormat.getInstance(Locale.GERMAN);
                Object obj2 = null;
                // 基于格式的解析
                try {
                    obj2 = nf2.parse("1234,56");
                }
                catch (ParseException e2) {
                    System.err.println(e2);
                }
                System.out.println(obj2);
            }
        }这个例子分两部分,都是解析一个字符串:"1234,56"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:
        123456
        1234.56
    换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。
    还有格式化讨论的最后一个问题。在上面的例子中, DecimalFormat 和 NumberFormat 都被使用了。DecimalFormat 常用于获得很好的格式控制,而NumberFormat 常用于指定不同于本地的地区。如何结合两个类呢?
    答案围绕着这样的事实:DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance 指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。下面是一个这样的例子:
        
    import java.text.DecimalFormat;
        import java.text.NumberFormat;
        import java.util.Locale;
        public class DecimalFormat6 {
            public static void main(String args[]) {
                DecimalFormat df = null;
                // 得到一个NumberFormat 对象并
                // 强制转换为一个 DecimalFormat 对象
                try {
                    df = (DecimalFormat)
                        NumberFormat.getInstance(Locale.GERMAN);
                }
                catch (ClassCastException e) {
                    System.err.println(e);
                }
                // 设置格式模式
                df.applyPattern("####.00000");
                // format a number
                System.out.println(df.format(1234.56));
            }
        } 
    getInstance() 方法获得格式,然后调用applyPattern()方法设置格式模式,输出:
        1234,56000
    如果你不关心国际化,可以直接使用DecimalFormat 。
      

  15.   

    想打印的话,可不可以把你的结果变成 String 按 ‘  .  ’给切成两部分;
    再分别转成数字最后判断下再用String连接起来。
      

  16.   

    你可以尝试如下方法:import java.math.*;
    public class Test { //使用递归去掉最后的零--开始//
    public static String deleteZero(String result){
    //String tmp="";
    if(result.length()<1){
    return "计算结果长度小于1";
    }
    if(result.lastIndexOf("0")==result.length() - 1||result.lastIndexOf(".")==result.length() - 1){
    result=result.substring(0,result.length() - 1);
    }else{
    return result;
    }
    return deleteZero(result);
    }
    //使用递归去掉最后的零--结束//    public static String  mul(double v1,double v2){ 
            BigDecimal b1 = new BigDecimal(Double.toString(v1)); 
            BigDecimal b2 = new BigDecimal(Double.toString(v2)); 
            return b1.multiply(b2).toPlainString();
        }
    public static void main(String[]args) {
    System.out.println(mul(12,0.000000000000000000180));
    System.out.println(deleteZero(mul(12,0.000000000000000000180)));

    System.out.println(mul(4345,0.0000012121));
    System.out.println(deleteZero(mul(4345,0.0000012121))); System.out.println(mul(12,1.08000000000000000000000000000000000000000000));
    System.out.println(deleteZero(mul(12,1.08000000000000000000000000000000000000000000)));
    }
    }
      

  17.   

    关键思路:1 使用String保存b1.multiply(b2)的结果。注意:b1.multiply(b2).toPlainString() //返回不带指数的此BigDecimal 的字符串表示形式。2 使用deleteZero(String result) 删除计算结果中的最后一个零(递归)楼主将代码拷贝 运行一下 看是否能满足要求
      

  18.   

    22楼的代码有个小bug ,请使用这个:import java.math.*;
    public class Test {
    //使用递归去掉最后的零--开始//
    public static String deleteZero(String result){
    if(result.lastIndexOf(".")==-1){
    return result;
    }else if(result.lastIndexOf("0")==result.length() - 1||result.lastIndexOf(".")==result.length() - 1){
    result=result.substring(0,result.length() - 1);
    }else{
    return result;
    }
    return deleteZero(result);
    }
    //使用递归去掉最后的零--结束//    public static String  mul(double v1,double v2){ 
            BigDecimal b1 = new BigDecimal(Double.toString(v1)); 
            BigDecimal b2 = new BigDecimal(Double.toString(v2)); 
            return b1.multiply(b2).toPlainString();
        }
    public static void main(String[]args) {
    System.out.println(deleteZero(mul(12,0.000000000000000000180)));
    System.out.println(deleteZero(mul(4345,0.0000012121)));
    System.out.println(deleteZero(mul(12,5.00)));
    System.out.println(deleteZero(mul(12,1)));
    }
    }