zoukankan      html  css  js  c++  java
  • Java API —— BigDecimal类

    1、BigDecimal类概述        

       由于在运算的时候,float类型和double很容易丢失精度,演示案例。所以,为了能精确的表示、计算浮点数,Java提供了BigDecimal   

      不可变的、任意精度的有符号十进制数。   

    2、构造方法

      public BigDecimal(String val):建议使用参数为字符串的构造方法,如果参数为double或float,还是会出现不可预知的精度问题

    3、BigDecimal类成员方法
      public BigDecimal add(BigDecimal augend):加        
      public BigDecimal subtract(BigDecimal subtrahend):减        
      public BigDecimal multiply(BigDecimal multiplicand):乘        
      public BigDecimal divide(BigDecimal divisor):除        
      public BigDecimal divide(BigDecimal divisor,int scale, int roundingMode):商,几位小数,舍取模式
     
    举例1:
    /**
     * 看程序写结果:结果和我们想的有一点点不一样,这是因为float类型的数据存储和整数不一样导致的。它们大部分的时候,都是带有有效数字位。
     * 由于在运算的时候,float类型和double很容易丢失精度,演示案例。所以,为了能精确的表示、计算浮点数,Java提供了BigDecimal
     * BigDecimal类:不可变的、任意精度的有符号十进制数,可以解决数据丢失问题。
     */
    public class BigDecimalDemo01 {
        public static void main(String[] args) {
            //输出会出现精度问题
            System.out.println(0.09 + 0.01); //0.09999999999999999
            System.out.println(1.0 - 0.32); //0.6799999999999999
            System.out.println(1.015 * 100); //101.49999999999999
            System.out.println(1.301 / 100); //0.013009999999999999
            System.out.println(1.0 - 0.12); //0.88
        }
    }

    举例2:

    public class BigDecimalDemo02 {
        public static void main(String[] args) {
            BigDecimal bd1 = new BigDecimal("0.09");
            BigDecimal bd2 = new BigDecimal("0.01");
            System.out.println("add:"+bd1.add(bd2));
            System.out.println("------------------");
            BigDecimal bd3 = new BigDecimal("1.0");
            BigDecimal bd4 = new BigDecimal("0.32");
            System.out.println("subtract:"+bd3.subtract(bd4));
            System.out.println("------------------");
            BigDecimal bd5 = new BigDecimal("1.015");
            BigDecimal bd6 = new BigDecimal("100");
            System.out.println("multiply:"+bd5.multiply(bd6));
            System.out.println("------------------");
            BigDecimal bd7 = new BigDecimal("1.301");
            BigDecimal bd8 = new BigDecimal("100");
            System.out.println("divide:"+bd7.divide(bd8));
            System.out.println("divide:"
                    + bd7.divide(bd8, 3, BigDecimal.ROUND_HALF_UP));
            System.out.println("divide:"
                    + bd7.divide(bd8, 8, BigDecimal.ROUND_HALF_UP));
            System.out.println("------------------");
        }
    }
    输出结果:
    add:0.10
    ------------------
    subtract:0.68
    ------------------
    multiply:101.500
    ------------------
    divide:0.01301
    divide:0.013
    divide:0.01301000
    ------------------
  • 相关阅读:
    c++链表实现学生成绩管理系统(简易版)
    IOS动画讲解
    栈的实现
    Masonry的使用
    二叉树详解-2
    二叉树详解-1
    CoreData的使用-2
    NSPredicate 详解
    CoreData的使用-1
    IOS常用手势用法
  • 原文地址:https://www.cnblogs.com/yangyquin/p/5023996.html
Copyright © 2011-2022 走看看