BigInteger类和BigDecimal

BigInteger
 

概述:

在 Java 中,有许多数字处理的类,比如 Integer类,但是Integer类有一定的局限性。
● 我们都知道 Integer 是 Int 的包装类,int 的最大值为 2^31-1。若希望描述更大的
整数数据时,使用Integer 数据类型就无法实现了,所以Java中提供了BigInteger 类。
● BigInteger类型的数字范围较Integer,Long类型的数字范围要大得多,它支持任意
精度的整数,也就是说在运算中 BigInteger 类型可以准确地表示任何大小的整数值而
不会丢失任何信息。(位于java。marh类)

代码实例

BigInteger a = new BigInteger("11111111111111111111111111111111111111");

BigInteger b = new BigInteger("99999999999999999999999999999999999999");

BigInteger c= a.add(b);

System.out.println(a);

System.out.println(b);

System.out.println(c);

BigDecimal

概述

在计算机中float 还是double都是浮点数,而计算机是二进制的,浮点数会失
去一定的精确度。
● 根本原因是:十进制浮点值没有完全相同的二进制表示形式;十进制浮点值的二进
制表示形式不精确,只能无限接近于那个值.
System.out.println((0.1 + 0.2)==0.3);//结果是?
但是,在项目中,我们不可能让这种情况出现,特别是金融项目,因为涉及金
额的计算都必须十分精确,你想想,如果你的支付宝账户余额显示
193.99999999999998,那是一种怎么样的体验?
• Java在java.math包中提供的API类BigDecimal

代码实例

public static void main(String[] args) {

//System.out.println((0.1 + 0.2)==0.3);

//System.out.println((0.1 + 0.2));

/*BigDecimal a = new BigDecimal("0.1");

BigDecimal b = new BigDecimal("0.2");

BigDecimal c = a.add(b);

System.out.println(c);*/

BigDecimal a = new BigDecimal("10");

BigDecimal b = new BigDecimal("3"); //3.11111

//在除法运算时,默认遇到无限循环会报错, 需要指定保留的小数位数,以及近似值的策略

BigDecimal c = a.divide(b,2,BigDecimal.ROUND_FLOOR);

System.out.println(c);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值