概述
关于java中数值无法精确计算是的解决方法,我觉得主要是因为计算机是以二进制进行计算的,因此并不能完全的表示所有的浮点数,而是在
各种语言内部有自己的优化算法。这里根据别的资料我编写一个ArithUtil,调用BigDecimal类以方便计算,以下是代码
package StudyFile;
import java.math.BigDecimal;
public class ArithUtil {
private static final int DEF_DIV_SCALE=10;
private ArithUtil(){
}
static Double add(double v1,double v2){
BigDecimal b1=new BigDecimal(Double.toString(v1));
BigDecimal b2=new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
static Double sub(double v1,double v2){
BigDecimal b1=new BigDecimal(Double.toString(v1));
BigDecimal b2=new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
static Double mul(double v1,double v2){
BigDecimal b1=new BigDecimal(Double.toString(v1));
BigDecimal b2=new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
static Double div(double v1,double v2){
BigDecimal b1=new BigDecimal(Double.toString(v1));
BigDecimal b2=new BigDecimal(Double.toString(v2));
return b1.divide(b2).doubleValue();
}
}
package StudyFile;
public class TestArithUtil {
public void test(){
System.out.println(0.05+0.01);
System.out.println(1-0.42);
System.out.println(4.015*100);
System.out.println(123.3/100);
}
public void test2(){
System.out.println(ArithUtil.add(0.05,0.01));
System.out.println(ArithUtil.sub(1, 0.42));
System.out.println(ArithUtil.mul(4.015, 100));
System.out.println(ArithUtil.div(123.3, 100));
}
public static void main(String[] args){
TestArithUtil test1=new TestArithUtil();
test1.test();
test1.test2();
}
}
一下是主程序运行结果:
0.060000000000000005
0.5800000000000001
401.49999999999994
1.2329999999999999
0.5800000000000001
401.49999999999994
1.2329999999999999
0.06
0.58
401.5
1.233
0.58
401.5
1.233
最后
以上就是超帅斑马为你收集整理的java中ArithUtil的计算方法的全部内容,希望文章能够帮你解决java中ArithUtil的计算方法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复