怎么用BigDecimal实现大数字运算?

一般float和double型数据用来做科学计算与工程计算,当用于商业计算中要求数字精度比较高时,就要用到java.math.BigDecimal类


import java.math.BigDecimal;
class BigDecimalDemo 
{
	static final int location = 10; //小数点后位数
	//加法 返回 num1+num2
	public double add(double num1, double num2){
		BigDecimal b1 = new BigDecimal(num1);
		BigDecimal b2 = new BigDecimal(num2);
		return b1.add(b2).doubleValue();
	}
	//减法 返回 num1-num2
	public double sub(double num1, double num2){
		BigDecimal b1 = new BigDecimal(num1);
		BigDecimal b2 = new BigDecimal(num2);
		return b1.subtract(b2).doubleValue();
	}
	//乘法 返回 num1*num2
	public double mul(double num1, double num2){
		BigDecimal b1 = new BigDecimal(num1);
		BigDecimal b2 = new BigDecimal(num2);
		return b1.multiply(b2).doubleValue();
	}
	//除法 返回 num1/num2
	public double div(double num1, double num2){
		return div(num1,num2,location);
	}
	//除法 返回num1/num2 自定义小数点后位数
	public double div(double num1, double num2, int _location){
		BigDecimal b1 = new BigDecimal(num1);
		BigDecimal b2 = new BigDecimal(num2);
		return b1.divide(b2,_location,BigDecimal.ROUND_HALF_UP).doubleValue();
	}


	public static void main(String[] args) 
	{
		BigDecimalDemo bd = new BigDecimalDemo();
		System.out.println(bd.add(12.123123,2));  //14.123123
		System.out.println(bd.sub(12.123,5.1)); //7.023
		System.out.println(bd.mul(9.99999,8.8888)); //88.887911112
		System.out.println(bd.div(13,3));  //4.3333333333  小数点后10位
		System.out.println(bd.div(13,3,20));  //4.333333333333333  小数点后15位

		double b = 4.123123123123123123123123123;  //4.123123123123123   double小数点后15位
		System.out.println(b);

		BigDecimal b2 = new BigDecimal(4.123123123123123123123123123); //4.12312312312312290174531881348229944705963134765625
		System.out.println(b2);
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BigDecimal是Java中一个用来处理高精度数字的类,可以实现精确的浮点数计算,避免了传统的double和float类型在计算时的精度丢失问题。BigDecimal类提供了基本的加、减、乘、除等运算方法,还可以进行舍入、比较、求幂等高级运算。 下面是BigDecimal运算的一些示例: 1. 加法运算 ```java BigDecimal num1 = new BigDecimal("2.5"); BigDecimal num2 = new BigDecimal("3.7"); BigDecimal sum = num1.add(num2); System.out.println(sum); // 输出6.2 ``` 2. 减法运算 ```java BigDecimal num1 = new BigDecimal("5.8"); BigDecimal num2 = new BigDecimal("2.5"); BigDecimal diff = num1.subtract(num2); System.out.println(diff); // 输出3.3 ``` 3. 乘法运算 ```java BigDecimal num1 = new BigDecimal("2.5"); BigDecimal num2 = new BigDecimal("3.7"); BigDecimal product = num1.multiply(num2); System.out.println(product); // 输出9.25 ``` 4. 除法运算 ```java BigDecimal num1 = new BigDecimal("8.5"); BigDecimal num2 = new BigDecimal("2"); BigDecimal quotient = num1.divide(num2); System.out.println(quotient); // 输出4.25 ``` 5. 取余运算 ```java BigDecimal num1 = new BigDecimal("9.5"); BigDecimal num2 = new BigDecimal("2"); BigDecimal remainder = num1.remainder(num2); System.out.println(remainder); // 输出1.5 ``` 6. 比较运算 ```java BigDecimal num1 = new BigDecimal("5.8"); BigDecimal num2 = new BigDecimal("2.5"); int result = num1.compareTo(num2); if(result > 0) { System.out.println("num1大于num2"); } else if(result < 0) { System.out.println("num1小于num2"); } else { System.out.println("num1等于num2"); } ``` 7. 舍入运算 ```java BigDecimal num1 = new BigDecimal("3.1415926"); BigDecimal round = num1.setScale(3, RoundingMode.HALF_UP); System.out.println(round); // 输出3.142 ``` 在进行BigDecimal运算时,需要注意以下几点: 1. 应该使用字符串作为BigDecimal的构造参数,而不是使用double或float类型,因为这样可以避免精度丢失问题。 2. 进行除法运算时,应该指定除法运算的精度和舍入规则。 3. 在进行比较运算时,应该使用compareTo()方法,而不是使用equals()方法,因为equals()方法只能判断两个BigDecimal对象是否相等,而compareTo()方法可以判断两个BigDecimal对象的大小关系。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值