java.text.DecimalFormat myformat=new java.text.DecimalFormat("#0.00");
//然后就用:
myformat.format(a);
//如:
double a;
a= 3.1415926;
System.out.println(myformat.format(a));
//或者
//4舍5入法
double a=3.1415926 ;
BigDecimal a=new BigDecimal(f);
double af = b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();
Math.round();用于4舍5入.
ROUND_HALF_UP: 遇到.5的情况时往上近似,例: 1.5 ->;2
ROUND_HALF_DOWN : 遇到.5的情况时往下近似,例: 1.5 ->;1
BigDecimal a = new BigDecimal(1.5);
System.out.println("down="+a.setScale(0,BigDecimal.ROUND_HALF_DOWN)+"\tup="+a.setScale(0,BigDecimal.ROUND_HALF_UP));
结果:down=1 up=2
Math.floor()、Math.ceil()、BigDecimal都是Java中的取整函数,但返回值却不一样
Math.floor()
通过该函数计算后的返回值是舍去小数点后的数值
如:Math.floor(3.2)返回3
Math.floor(3.9)返回3
Math.floor(3.0)返回3
Math.ceil()
ceil函数只要小数点非0,将返回整数部分+1
如:Math.ceil(3.2)返回4
Math.ceil(3.9)返回4
Math.ceil(3.0)返回3
BigDecimal四舍五入
传统的四舍五入,在Math类中并没有直接提供,必须使用Java.math.BigDecimal类来实现
new BigDecimal("2.0").setScale(0, BigDecimal.ROUND_HALF_UP)返回2
new BigDecimal("2.4").setScale(0, BigDecimal.ROUND_HALF_UP)返回2
new BigDecimal("2.5").setScale(0, BigDecimal.ROUND_HALF_UP)返回3
package com.ics8000.util;
import java.math.BigDecimal;
public class MathExtend
{
// 默认除法运算精度
public static final int DEFAULT_DIV_SCALE = 2;
/**
*
* 提供精确的加法运算。
*
* @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 String add(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.add(b2).toString();
}
/**
*
* 提供精确的减法运算。
*
* @param v1
*
* @param v2
*
* @return 两个参数的差
*
*/
public static double subtract(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 String subtract(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.subtract(b2).toString();
}
/**
*
* 提供精确的乘法运算。
*
* @param v1
*
* @param v2
*
* @return 两个参数的积
*
*/
public static double multiply(double v1, double v2)
{
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
/**
*
* 提供精确的乘法运算
*
* @param v1
*
* @param v2
*
* @return 两个参数的数学积,以字符串格式返回
*
*/
public static String multiply(String v1, String v2)
{
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.multiply(b2).toString();
}
/**
*
* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
*
* 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
*
* @param v1
*
* @param v2
*
* @return 两个参数的商
*
*/
public static double divide(double v1, double v2)
{
return divide(v1, v2, DEFAULT_DIV_SCALE);
}
/**
*
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
*
* 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
*
* @param v1
*
* @param v2
*
* @param scale
* 表示需要精确到小数点以后几位。
*
* @return 两个参数的商
*
*/
public static double divide(double v1, double v2, int scale)
{
return divide(v1, v2, scale, BigDecimal.ROUND_HALF_EVEN);
}
/**
*
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
*
* 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式
*
* @param v1
*
* @param v2
*
* @param scale
* 表示需要精确到小数点以后几位
*
* @param round_mode
* 表示用户指定的舍入模式
*
* @return 两个参数的商
*
*/
public static double divide(double v1, double v2, int scale, int round_mode) {
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, round_mode).doubleValue();
}
/**
*
* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
*
* 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
*
* @param v1
*
* @param v2
*
* @return 两个参数的商,以字符串格式返回
*
*/
public static String divide(String v1, String v2)
{
return divide(v1, v2, DEFAULT_DIV_SCALE);
}
/**
*
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
*
* 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
*
* @param v1
*
* @param v2
*
* @param scale
* 表示需要精确到小数点以后几位
*
* @return 两个参数的商,以字符串格式返回
*
*/
public static String divide(String v1, String v2, int scale)
{
return divide(v1, v2, DEFAULT_DIV_SCALE, BigDecimal.ROUND_HALF_EVEN);
}
/**
*
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
*
* 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式
*
* @param v1
*
* @param v2
*
* @param scale
* 表示需要精确到小数点以后几位
*
* @param round_mode
* 表示用户指定的舍入模式
*
* @return 两个参数的商,以字符串格式返回
*
*/
public static String divide(String v1, String v2, int scale, int round_mode)
{
if (scale < 0)
{
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.divide(b2, scale, round_mode).toString();
}
/**
*
* 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN
*
* @param v
* 需要四舍五入的数字
*
* @param scale
* 小数点后保留几位
*
* @return 四舍五入后的结果
*
*/
public static double round(double v, int scale)
{
return round(v, scale, BigDecimal.ROUND_HALF_EVEN);
}
/**
*
* 提供精确的小数位四舍五入处理
*
* @param v
* 需要四舍五入的数字
*
* @param scale
* 小数点后保留几位
*
* @param round_mode
* 指定的舍入模式
*
* @return 四舍五入后的结果
*
*/
public static double round(double v, int scale, int round_mode)
{
if (scale < 0)
{
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(Double.toString(v));
return b.setScale(scale, round_mode).doubleValue();
}
/**
*
* 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN
*
* @param v
* 需要四舍五入的数字
*
* @param scale
* 小数点后保留几位
*
* @return 四舍五入后的结果,以字符串格式返回
*
*/
public static String round(String v, int scale)
{
return round(v, scale, BigDecimal.ROUND_HALF_EVEN);
}
/**
*
* 提供精确的小数位四舍五入处理
*
* @param v
* 需要四舍五入的数字
*
* @param scale
* 小数点后保留几位
*
* @param round_mode
* 指定的舍入模式
*
* @return 四舍五入后的结果,以字符串格式返回
*
*/
public static String round(String v, int scale, int round_mode)
{
if (scale < 0)
{
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(v);
return b.setScale(scale, round_mode).toString();
}
/**
* 要求舍入后返回BigDecimal类型
*
* @param dou
* 待舍入的数字
* @param scale
* 返回的BigDecimal对象的标度(scale)
* @param roundmode
* 舍入模式
* @return
*/
public static BigDecimal getRound(double dou, int scale, int roundmode) {
// 创建一个新的BigDecimal对象paramNumber,该对象的值和dou大小一样。
BigDecimal paramNumber = new BigDecimal(dou);
// 然后调用paramNumber的setScale方法,该方法返回一个 BigDecimal对象temp,
// 返回值的标度为第一个参数指定的值,标度为大小表示小数部分的位数
// 第二个参数指定了paramNumber对象到temp对象的舍入模式,如四舍五入等。
return paramNumber.setScale(scale, roundmode);
// 实际可以一条语句实现:return new BigDecimal(dou).setScale(0, roundmode);
}
}