bigdecimal与double
来源:互联网 发布:昆明java 编辑:程序博客网 时间:2024/06/05 05:31
BigDecimal类
对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用BigDecimal类,而且使用BigDecimal类也可以进行大数的操作。BigDecimal类的常用方法如表11-15所示。
表11-15 BigDecimal类的常用方法
序号
方 法
类型
描 述
1
public BigDecimal(double val)
构造
将double表示形式转换
为BigDecimal
2
public BigDecimal(int val)
构造
将int表示形式转换为
BigDecimal
3
public BigDecimal(String val)
构造
将字符串表示
形式转换为BigDecimal
4
public BigDecimal add(BigDecimal augend)
普通
加法
5
public BigDecimal subtract(BigDecimal
subtrahend)
普通
减法
6
public BigDecimal multiply(BigDecimal
multiplicand)
普通
乘法
7
public BigDecimal divide(BigDecimal
divisor)
普通
除法
范例:进行四舍五入的四则运算
package org.lxh.demo11.numberdemo; import java.math.BigDecimal; class MyMath { public static double add(double d1, double d2) { // 进行加法运算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.add(b2).doubleValue(); } public static double sub(double d1, double d2) { // 进行减法运算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.subtract(b2).doubleValue(); } public static double mul(double d1, double d2) { // 进行乘法运算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.multiply(b2).doubleValue(); } public static double div(double d1, double d2,int len) {// 进行除法运算 BigDecimal b1 = new BigDecimal(d1); BigDecimal b2 = new BigDecimal(d2); return b1.divide(b2,len,BigDecimal. ROUND_HALF_UP).doubleValue(); } public static double round(double d, int len) { // 进行四舍五入 操作 BigDecimal b1 = new BigDecimal(d); BigDecimal b2 = new BigDecimal(1); // 任何一个数字除以1都是原数字 // ROUND_HALF_UP是BigDecimal的一个常量, 表示进行四舍五入的操作 return b1.divide(b2, len,BigDecimal. ROUND_HALF_UP).doubleValue(); } } public class BigDecimalDemo01 { public static void main(String[] args) { System.out.println("加法运算:" + MyMath.round(MyMath.add(10.345, 3.333), 1)); System.out.println("乘法运算:" + MyMath.round(MyMath.mul(10.345, 3.333), 3)); System.out.println("除法运算:" + MyMath.div(10.345, 3.333, 3)); System.out.println("减法运算:" + MyMath.round(MyMath.sub(10.345, 3.333), 3)); } }
BigDecimal是Java中用来表示任意精确浮点数运算的类,在BigDecimal中,使用unscaledValue × 10-scale来表示一个浮点数。其中,unscaledValue是一个BigInteger,scale是一个int。从这个表示方法来看,BigDecimal只能标识有限小数,不过可以表示的数据范围远远大于double,在实际应用中基本足够了。
System.out.println(new BigDecimal(0.1).toString()); // 0.1000000000000000055511151231257827021181583404541015625System.out.println(new BigDecimal("0.1").toString()); // 0.1System.out.println(new BigDecimal(Double.toString(0.1000000000000000055511151231257827021181583404541015625)).toString());// 0.1System.out.println(new BigDecimal(Double.toString(0.1)).toString()); // 0.1
分析一下上面代码的问题(注释的内容表示此语句的输出)
int x=(int)1023.99999999999999; // x=1024为什么?
原因还是在于二进制无法精确地表示某些十进制小数,因此1023.99999999999999在编译之后的double值变成了1024。
double d = 1023.99999999999999;int x = (int) d;System.out.println(new BigDecimal(d).toString()); // 1024System.out.println(Long.toHexString(Double.doubleToRawLongBits(d))); // 4090000000000000System.out.println(x); // 1024
前面提过BigDecimal可以精确地把double表示出来还记得吧。
- bigdecimal与double
- BigDecimal与double
- Double与BigDecimal 精度问题
- Double与BigDecimal 精度问题
- Double与BigDecimal 精度问题
- Double与BigDecimal 精度问题
- Double || BigDecimal
- BigDecimal(double)
- double bigdecimal
- 关于BigDecimal(Double.toString(double val))与BigDecimal(double val)的区别
- Java中运算精度的问题(double与BigDecimal)
- BigDecimal,Double精度问题
- Java BigDecimal和double
- Java BigDecimal和double
- Java BigDecimal和double
- BigDecimal勿用double构造
- int float double BigDecimal
- double和Bigdecimal
- 深度学习 tensorflow例子
- Mac下Intellij IDEA快捷键部分失效
- Apache_tomcat和jakarta_tomcat区别
- MAC终端自动提示
- Thinkphp 3.23 动态验证
- bigdecimal与double
- 针对正方教务开发大学App(查成绩,课表,一键评教,图书馆,正方系统)
- Idea 的@Autowired标红报错
- shell脚本 编写
- tomcat7放入war不解析
- Java异常类层次结构图
- SpringBoot从入门到高级
- 观察者模式
- Qt QWizard学习 当需要验证输入时