Java-精确计算工具类
import java.math.BigDecimal;
import java.math.RoundingMode; /**
* 精确计算工具类(加,减,乘,除,返回较大值,返回较小值)
*/
public class CalculationUtil { /**
* 提供精确加法计算的add方法
*/
public static String add(String value1, String value2) {
return add(value1, value2, 0, 0);
} /**
* 提供精确加法计算的add方法(默認四捨五入)
* @param value1 被加数
* @param value2 加数
* @param scale 精确范围(小数点后几位)
*/
public static String add(String value1, String value2, int scale) {
return add(value1, value2, scale, BigDecimal.ROUND_HALF_UP);
} /**
* 提供精确加法计算的add方法
* @param value1 被加数
* @param value2 加数
* @param scale 精确范围(小数点后几位)
* @param roundingMode 精確模式
*/
public static String add(String value1, String value2, int scale, int mode) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
BigDecimal result = b1.add(b2);
// mode为0,则不需要精确
if (mode != 0) {
result = result.setScale(scale, mode);
}
return result.toString();
} public static int compareTo(String value1, String value2, int scale, int mode) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
BigDecimal result = b1.subtract(b2);
// mode为0,则不需要精确
if (mode != 0) {
result = result.setScale(scale, mode);
}
return result.compareTo(BigDecimal.ZERO);
} /**
* 提供精确的除法运算方法divide
* @param value1 被除数
* @param value2 除数
*/
public static String divide(String value1, String value2) throws IllegalAccessException {
return divide(value1, value2, 0, null);
} /**
* 提供精确的除法运算方法divide(默認四捨五入)
* @param value1 被除数
* @param value2 除数
* @param scale 精确范围(小数点后几位)
*/
public static String divide(String value1, String value2, int scale) throws IllegalAccessException {
return divide(value1, value2, scale, RoundingMode.HALF_UP);
} /**
* 提供精确的除法运算方法divide
*
* @param value1 被除数
* @param value2 除数
* @param scale 精确范围(小数点后几位)
* @param roundingMode 精確模式
*/
public static String divide(String value1, String value2, int scale, RoundingMode roundingMode)
throws IllegalAccessException {
// 如果精确范围小于0,抛出异常信息
if (scale < 0) {
throw new IllegalAccessException("精确度不能小于0");
}
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
// roundingMode为null,则不需要精确
if (roundingMode != null) {
return new Double(b1.divide(b2, scale, roundingMode).doubleValue()).toString();
} else {
return new Double(b1.divide(b2).doubleValue()).toString();
}
} /**
* 比较大小 :返回较大的那个
*/
public static String getMax(String value1, String value2) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
return new Double(b1.max(b2).doubleValue()).toString();
} /**
* 比较大小 :返回较小的那个
*/
public static String getMin(String value1, String value2) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
return new Double(b1.min(b2).doubleValue()).toString();
} /**
*
* 提供精确乘法运算的multiply方法
* @param value1 被乘数
* @param value2 乘数
* @return 两个参数的积
*/
public static String multiply(String value1, String value2) {
return multiply(value1, value2, 0, 0);
} /**
* 提供精确乘法运算的multiply方法(默認四捨五入)
* @param value1 被乘数
* @param value2 乘数
* @param scale 精确范围(小数点后几位)
*/
public static String multiply(String value1, String value2, int scale) {
return multiply(value1, value2, scale, BigDecimal.ROUND_HALF_UP);
} /**
* 提供精确乘法运算的multiply方法
* @param value1 被乘数
* @param value2 乘数
* @param scale 精确范围(小数点后几位)
* @param roundingMode 精確模式
*/
public static String multiply(String value1, String value2, int scale, int mode) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
BigDecimal result = b1.multiply(b2);
// mode为0,则不需要精确
if (mode != 0) {
result = result.setScale(scale, mode);
}
return result.toString();
} /**
* 提供精确减法运算的subtract方法
* @param value1 被减数
* @param value2 减数
* @return 两个参数的差
*/
public static String subtract(String value1, String value2) {
return subtract(value1, value2, 0, 0);
} /**
* 提供精确减法运算的subtract方法(默認四捨五入)
* @param value1 被减数
* @param value2 减数
* @param scale 精确范围(小数点后几位)
*/
public static String subtract(String value1, String value2, int scale) {
return subtract(value1, value2, scale, BigDecimal.ROUND_HALF_UP);
} /**
* 提供精确减法运算的subtract方法
* @param value1 被减数
* @param value2 减数
* @param scale 精确范围(小数点后几位)
* @param roundingMode 精確模式
*/
public static String subtract(String value1, String value2, int scale, int mode) {
BigDecimal b1 = new BigDecimal(Double.valueOf(value1));
BigDecimal b2 = new BigDecimal(Double.valueOf(value2));
BigDecimal result = b1.subtract(b2);
// mode为0,则不需要精确
if (mode != 0) {
result = result.setScale(scale, mode);
}
return result.toString();
}
}
Java-精确计算工具类的更多相关文章
- java精确计算工具类
java精确计算工具类 import java.math.BigDecimal; import java.math.RoundingMode; import java.math.BigDecimal; ...
- BigDecimal精确计算工具类
前言 在实际开发中,遇到例如货币,统计等商业计算的时候,一般需要采用java.math.BigDecimal类来进行精确计算.而这类操作通常都是可预知的,也就是通用的.所以,写了个工具类来方便以后的工 ...
- java精确计算、精确计算工具类
java精确计算 package org.aisino.erp.webservice.dzfp.util; import java.math.BigDecimal; public class Math ...
- JAVA简单精确计算工具类
1 public class ArithUtil { 2 3 // 默认除法运算精度 4 private static final int DEF_DIV_SCALE = 10; 5 6 privat ...
- 使用BigDecimal进行精确计算工具类
package com.develop.util; import java.math.BigDecimal; import java.math.RoundingMode; public class M ...
- Java精确计算
Java精确计算 如果我们编译运行下面这个程序会看到什么? public class Test{ public static void main(String args[]){ System.out. ...
- HttpTool.java(在java tool util工具类中已存在) 暂保留
HttpTool.java 该类为java源生态的http 请求工具,不依赖第三方jar包 ,即插即用. package kingtool; import java.io.BufferedReader ...
- java文件处理工具类
import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.BufferedRead ...
- java格式处理工具类
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOExceptio ...
随机推荐
- PHP面向对象——三大基本特性与五大基本原则
三大特性是:封装.继承.多态 所谓封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏. 封装是面向对象的特征之一,是对象和类概念的主要特 ...
- piezo film 压电相关信息记录 (2018-05-04 更新)
piezo film 压电相关信息记录 起因需要使用 Piezo 做一些设计 http://www.te.com.cn/chn-zh/videos/transportation/piezo-film- ...
- gitlab安装、配置与阿里云产品集成
https://www.ilanni.com/?p=12819 一.gitlab安装与部署 gitlab的安装可以分为源码安装和通过安装包进行安装,要是按照我以前的写作习惯的话,我也会把源码安装在本文 ...
- Hadoop序列化与Writable接口(一)
Hadoop序列化与Writable接口(一) 序列化 序列化(serialization)是指将结构化的对象转化为字节流,以便在网络上传输或者写入到硬盘进行永久存储:相对的反序列化(deserial ...
- php 数据库类
<?php /** * 对Yii2数据封装 * @author nike@youfumama.com * @date 2017-03-08 * 抽象类不能被实例化 * eg1: select u ...
- C++中const使用注意要点(一)
最近看<C++编程思想>发现自己的基础确实不牢固,也想起了以前写代码时也因为const的事情浪费过时间,这里总结下几个要点. 首先说下内部链接和外部链接. 当一个cpp文件在编译时,预处理 ...
- css loading 效果
.loading{ width:160px; height:56px; position: absolute; top:50%; left:50%; line-height:56px; color:# ...
- 定位SDK返回时间问题
关于怎么使用定位SDK ,这里不做介绍,可以去看api:http://developer.baidu.com/map/index.php?title=android-locsdk/guide/v5-0 ...
- http的含义
HTTP是超文本传输协议,是客户端浏览器或其他程序与Web服务器之间的应用层通信协议.在Internet上的Web服务器上存放的都是 超文本信息,客户机需要通过HTTP协议传输所要访问的超文本信息.H ...
- canvas之绘制一张图片
<canvas id="canvas" width="600" height="500" style="background ...