java保留指定⼩数位数的⼯具类package com.viathink;
import java.math.BigDecimal;
/**
* 数字格式化⼯具类
* @author LiuJunGuang
* @date 2013-1-26上午10:44:08
*/
public class NumberUtils {
/**
* 格式化为指定位⼩数的数字,返回未使⽤科学计数法表⽰的具有指定位数的字符串。
* 该⽅法舍⼊模式:向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为向上舍⼊的舍⼊模式。
* <pre>
*  "3.1415926", 1  --> 3.1
*  "3.1415926", 3  --> 3.142
*  "3.1415926", 4  --> 3.1416
*  "3.1415926", 6  --> 3.141593
*  "1234567891234567.1415926", 3 --> 1234567891234567.142
* </pre>
* @param String类型的数字对象
bigdecimal除法保留小数
* @param precision  ⼩数精确度总位数,如2表⽰两位⼩数
* @return 返回数字格式化后的字符串表⽰形式(注意返回的字符串未使⽤科学计数法)
*/
public static String keepPrecision(String number, int precision) {
BigDecimal bg = new BigDecimal(number);
return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).toPlainString();
}
/**
* 格式化为指定位⼩数的数字,返回未使⽤科学计数法表⽰的具有指定位数的字符串。<br>
* 该⽅法舍⼊模式:向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为向上舍⼊的舍⼊模式。<br>
* 如果给定的数字没有⼩数,则转换之后将以0填充;例如:int 123  1 --> 123.0<br>
* <b>注意:</b>如果精度要求⽐较精确请使⽤ keepPrecision(String number, int precision)⽅法
* @param String类型的数字对象
* @param precision  ⼩数精确度总位数,如2表⽰两位⼩数
* @return 返回数字格式化后的字符串表⽰形式(注意返回的字符串未使⽤科学计数法)
*/
public static String keepPrecision(Number number, int precision) {
return keepPrecision(String.valueOf(number), precision);
}
/**
* 对double类型的数值保留指定位数的⼩数。<br>
* 该⽅法舍⼊模式:向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为向上舍⼊的舍⼊模式。<br>
* <b>注意:</b>如果精度要求⽐较精确请使⽤ keepPrecision(String number, int precision)⽅法
* @param number  要保留⼩数的数字
* @param precision ⼩数位数
* @return double 如果数值较⼤,则使⽤科学计数法表⽰
*/
public static double keepPrecision(double number, int precision) {
BigDecimal bg = new BigDecimal(number);
return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 对float类型的数值保留指定位数的⼩数。<br>
* 该⽅法舍⼊模式:向“最接近的”数字舍⼊,如果与两个相邻数字的距离相等,则为向上舍⼊的舍⼊模式。<br>
* <b>注意:</b>如果精度要求⽐较精确请使⽤ keepPrecision(String number, int precision)⽅法
* @param number  要保留⼩数的数字
* @param precision ⼩数位数
* @return float 如果数值较⼤,则使⽤科学计数法表⽰
* @return float 如果数值较⼤,则使⽤科学计数法表⽰
*/
public static float keepPrecision(float number, int precision) {
BigDecimal bg = new BigDecimal(number);
return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).floatValue(); }
}