网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  精确的浮点数运算(实际应用中经常用到)     
  文章作者:未知  文章来源:水木森林  
  查看:70次  录入:管理员--2007-11-17  
 

import java.math.bigdecimal;

 

/**

* 由于java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精

* 确的浮点数运算,包括加减乘除和四舍五入。

*/

public class arith{

 

//默认除法运算精度

private static final int def_div_scale = 10;

 

//这个类不能实例化

private arith(){

}

 

 

/**

* 提供精确的加法运算。

* @param v1 被加数

* @param v2 加数

* @return 两个参数的和

*/

public 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();

}

 

/**

* 提供精确的减法运算。

* @param v1 被减数

* @param v2 减数

* @return 两个参数的差

*/

public 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();

}

 

/**

* 提供精确的乘法运算。

* @param v1 被乘数

* @param v2 乘数

* @return 两个参数的积

*/

public 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();

}

 

/**

* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到

* 小数点以后10位,以后的数字四舍五入。

* @param v1 被除数

* @param v2 除数

* @return 两个参数的商

*/

public static double div(double v1,double v2){

return div(v1,v2,def_div_scale);

}

 

/**

* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指

* 定精度,以后的数字四舍五入。

* @param v1 被除数

* @param v2 除数

* @param scale 表示表示需要精确到小数点以后几位。

* @return 两个参数的商

*/

public static double div(double v1,double v2,int scale){

if(scale<0){

throw new illegalargumentexception(

"the scale must be a positive integer or zero");

}

bigdecimal b1 = new bigdecimal(double.tostring(v1));

bigdecimal b2 = new bigdecimal(double.tostring(v2));

return b1.divide(b2,scale,bigdecimal.round_half_up).doublevalue();

}

 

/**

* 提供精确的小数位四舍五入处理。

* @param v 需要四舍五入的数字

* @param scale 小数点后保留几位

* @return 四舍五入后的结果

*/

public static double round(double v,int scale){

if(scale<0){

throw new illegalargumentexception(

"the scale must be a positive integer or zero");

}

bigdecimal b = new bigdecimal(double.tostring(v));

bigdecimal one = new bigdecimal("1");

return b.divide(one,scale,bigdecimal.round_half_up).doublevalue();

}

};

 
 
上一篇: 审查java代码的十一种常见错误    下一篇: 用filter实现ip过滤
  相关文档
java的文件类和i/o系统简介 11-17
java应用程序中的按值传递语义 11-17
轻松掌握 java 泛型 (第 2 部分) 11-17
java多线程程序设计初步 11-16
sun在开放源代码j2ee认证上又迈出重要一步 11-17
分享关于jdk1.5 scanner类的说明 11-17
连接池用法 11-17
java编码中的一些经验和教训 11-17
调整 java i/o 性能 11-17
solaris上开发j2ee应用中文问题的解决 11-16
如何运行java程序和设置classpat 11-17
用jwsdp将java和web服务结合起来 11-17
jdk1.4新特性之i/o apis篇 11-17
webwork的拦截器(interceptor)使用方法 11-16
初学者如何快速入门jsp实例分析 11-17
认识了解“j2me” 11-17
图解jdeveloper 10g快速开发会话ejb(下) 11-17
microsoft jscript 特性 - 非-ecma 11-16
java多线程设计模式详解之四 11-17
在eclipse 3.1中体验j2se 5.0的新特性:第一部分:枚举类型 11-17
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
技术电话:13616026886
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息