货币运算:两个FLOAT型的数据相加 结果好比1.5+1.5应该是3.0 可是 却显示为了3.123332

问题:两个FLOAT型的数据相加 结果好比是1.5+1.5应该是3.0 可是 却显示为了3.123332

 

原因: 问题在于并不是所有的小数都可以用二进制浮点数来精确表示的。二进制浮点对于货币计算是非常不适合的,因为它不可能将0.1——或者10的其它任何次负幂——精确表示为一个长度有限的二进制小数。

 

解决方法:

     1.使用某种整数类型,例如int或long,并且以分为单位来执行计算。

       如果你采纳了此路线,请确保该整数类型大到足够表示在程序中你将要用到的所有值。

      2.解决该问题的另一种方式是使用执行精确小数运算的BigDecimal。

     它还可以通过JDBC与SQL DECIMAL类型进行互操作。这里要告诫你一点: 一定要用BigDecimal(String)构造器,而千万不要用BigDecimal(double)。后一个构造器将用它的参数的“精确”值来创建一个实例:new BigDecimal(.1)将返回一个表示0.100000000000000055511151231257827021181583404541015625的BigDecimal。通过正确使用BigDecimal,程序就可以打印出我们所期望的结果。

       这个版本并不是十分地完美,因为Java并没有为BigDecimal提供任何语言上的支持。使用BigDecimal的计算很有可能比那些使用原始类型的计算要慢一些,对某些大量使用小数计算的程序来说,这可能会成为问题,而对大多数程序来说,这显得一点也不重要。

总之:

在需要精确答案的地方,要避免使用float和double;对于货币计算,要使用int、long或BigDecimal。对于语言设计者来说,应该考虑对小数运算提供语言支持。一种方式是提供对操作符重载的有限支持,以使得运算符可以被塑造为能够对数值引用类型起作用,例如BigDecimal。另一种方式是提供原始的小数类型,就像COBOL与PL/I所作的一样。

 

例子:

 

import java.math.BigDecimal;
public class Decimaltest {
 public static void main(String[] args){
	 BigDecimal sum=new BigDecimal(0);
	 for(int i=0;i<3;i++){
		 BigDecimal a=new BigDecimal("1.52");	 
		 sum=sum.add(a);
		 System.out.println("+++"+a);		 
	}	 
	 System.out.println("==="+sum);
 
 }
}

 运算结果如下:

 

实际操作操作中还要过滤不能输入字母、要控制小数的位数。
如以下方法所示

/**
	 * 判断字符串是否是数字,只允许两位小数以内
	 * @param str
	 * @return true 或 false
	 */
	public static boolean isNumeric(String str){ 
	    Pattern pattern = Pattern.compile("^[0-9]+(.[0-9]{1,2})?$"); 
	    return pattern.matcher(str).matches();    
	 } 


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值