我是靠谱客的博主 明理服饰,这篇文章主要介绍java中解决double类型精度丢失问题(BigDecimal),现在分享给大家,希望可以做个参考。

BigDecimal类

对于不需要准确计算精度的数字可以直接使用float或double,但如果要精确计算结果,就必须使用BigDecimal类

public BigDecimal(double val)  将double表现形式转换为BigDecimal

public BigDecimal(int val)         将int表现形式转换成BigDecimal

public BigDecimal(String val)    将String表现形式转换成BigDecima

例:计算一个长方形的边长,每段解释在代码段

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import java.math.BigDecimal; import java.util.Scanner; public class Demo5 { public static void main(String[] args) { //调用perimeter类 double z = perimeter(); //输出z的值,发现精度丢失问题解决 System.out.println(z); } public static double perimeter() { //Scanner 用户输入 Scanner sc = new Scanner(System.in); //输入一个double类型数值给x,y double x = sc.nextDouble(); double y = sc.nextDouble(); //把输入的x,y值(长、宽)转成字符串类型给到b1,b2 BigDecimal b1= new BigDecimal(String.valueOf(x)); BigDecimal b2= new BigDecimal(String.valueOf(y)); BigDecimal b3= new BigDecimal("2.0"); //返回b1+b2再乘b3的值 return b1.add(b2).multiply(b3).doubleValue(); } }

随机输入两个数 如 10.1  10.2

计算结果 z = 40.6 

String.valueOf() -> 基本数据类型转换为字符串形式表现

复制代码
1
2
3
4
5
6
7
8
b1.add(b2).doubleValue(); //加法 b1.subtract(b2).doubleValue(); //减法 b1.multiply(b2).doubleValue(); //乘法 b1.divide(b2).doubleValue(); //除法

最后

以上就是明理服饰最近收集整理的关于java中解决double类型精度丢失问题(BigDecimal)的全部内容,更多相关java中解决double类型精度丢失问题(BigDecimal)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(71)

评论列表共有 0 条评论

立即
投稿
返回
顶部