本文初衷:主要是由于平时在写页面和后台程序的时候经常遇到小数点后保留几位,以及是否需要四舍五入的情况,总结一下。
1.页面程序,一般就是jstl标签格式化,如下所示:
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<fmt:formatNumber type="number" value="${231.34*2.3}" pattern="0.00" maxFractionDigits="2"/>
以上情况是默认四舍五入的,所以对于直接舍掉最后位的情况,只能通过后台java的方式解决。
2.以下列取了几种保留小数的方式,有四舍五入的和非四舍五入的,供参考:
保留两位小数{
方法一:{
double c=3.154215;
Java.text.DecimalFormat myformat=new java.text.DecimalFormat("0.00");
String str = myformat.format(c);
}
方式二:{
java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
df.format(你要格式化的数字);
例:new java.text.DecimalFormat("#.00").format(3.1415926)
#.00 表示两位小数 #.0000四位小数 以此类推...
}
方式三:{
double d = 3.1415926;
String result = String .format("%.2f");
%.2f %. 表示 小数点前任意位数 2 表示两位小数 格式后的结果为f 表示浮点型
}
}
四舍五入 {
double f = 111231.5585;
BigDecimal b = new BigDecimal(f);
//保留2位小数
double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
非四舍五入{
BigDecimal b = new BigDecimal(f);
//保留2位小数
b = b.setScale(2, BigDecimal.ROUND_DOWN); //主要是修改一下BigDecimal的枚举类型即可。
}
- public class PreciseCompute {
-
- private static final int DEF_DIV_SCALE = 10;
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
-
-
- public static double div(double v1, double v2) {
- return div(v1, v2, DEF_DIV_SCALE);
- }
-
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
- 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 ne = new BigDecimal("1");
- return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
- }
- }
my code:
- private BigDecimal formatComma2BigDecimal(Object obj) {
- String val = String.valueOf(obj);
- if (val == null)
- return new BigDecimal("0.00");
-
- val = val.replaceAll(",", "");
- if (!isNumber(val))
- return new BigDecimal("0.00");
-
- BigDecimal decimal = new BigDecimal(val);
- decimal = decimal.setScale(2, RoundingMode.HALF_UP);
-
- return decimal;
-
- }
- private String formatCommaAnd2Point(Object obj) {
- BigDecimal decimal = formatComma2BigDecimal(obj);
-
- DecimalFormat df = new DecimalFormat("#,###.00");
- String decimalStr = df.format(decimal).equals(".00")?"0.00":df.format(decimal);
- if(decimalStr.startsWith(".")){
- decimalStr = "0"+decimalStr;
- }
- return decimalStr;
- }
- private boolean isDouble(String value) {
- try {
- Double.parseDouble(value);
- if (value.contains("."))
- return true;
- return false;
- } catch (NumberFormatException e) {
- return false;
- }
- }
- private boolean isInteger(String value) {
- try {
- Integer.parseInt(value);
- return true;
- } catch (NumberFormatException e) {
- return false;
- }
- }
- private boolean isNumber(String value) {
- return isInteger(value) || isDouble(value);
- }