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 ...
随机推荐
- [LeetCode系列]组合和枚举问题
给定一列数(未排序)和一个目标值, 找出所有可能的组合和等于目标值的组合, 数组中的数可以重复使用. 算法思路: 使用递归. 对数组排序, 从小到大; 令i = 起始下标(初始为0), 对于每一个数, ...
- HBase之八--(3):Hbase 布隆过滤器BloomFilter介绍
布隆过滤器( Bloom filters) 数据块索引提供了一个有效的方法,在访问一个特定的行时用来查找应该读取的HFile的数据块.但是它的效用是有限的.HFile数据块的默认大小是64KB,这个大 ...
- [转载,感觉写的非常详细]DUBBO配置方式详解
[转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供 ...
- 004:MySQL数据库体系结构
目录 一. MySQL数据库体系结构 1.MySQL数据库体系结构介绍 1 数据库定义 2 数据库实例 2. MySQL体系结构 1 单进程多线程结构 2 存储引擎的概念 3 体系结构图 4 逻辑存储 ...
- 5月17日上课笔记-js面向对象
二.js面向对象 js创建对象: var 对象名称 = new Object(); person.name = "小明"; //姓名 person.age = 18; person ...
- SET STATISTICS IO
SET STATISTICS IO (Transact-SQL) https://technet.microsoft.com/zh-cn/library/ms184361(SQL.90).aspx 如 ...
- .NET自带IOC容器MEF之初体验(转)
本文主要把MEF作为一种IOC容器进行讲解,.net中可用的IOC容器非常多,如 CastleWindsor,Unity,Autofac,ObjectBuilder,StructureMap,Spri ...
- redis的二种启动方式
.直接启动 进入redis根目录,执行命令: #加上‘&’号使redis以后台程序方式运行 1 ./redis-server & 2.通过指定配置文件启动 可以为redis服务启 ...
- css伪类(Pseudo-classes)
简介:伪类(Pseudo classes)是选择符的螺栓,用来指定一个或者与其相关的选择符的状态.它们的形式是selector:pseudo class { property: value; },简单 ...
- C#对Excel的图文操作
1.打印Excel 目前的商业工具如水晶报表,ActiveReport等,都提供了灵活,强大的功能,但是对于比较特殊化的表格,特别是国内的一些应用,都是一个个的格子组成的,这样要是用线来一根根画就比较 ...