Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以开发中,如果我们需要精确计算的结果,则必须使用BigDecimal类来操作啦!
public class BigDecimalUtils
{
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, 10);
}
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, 4).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 one = new BigDecimal(“1”);
return b.divide(one, scale, 4).doubleValue();
}
public static double getTwoDecimal(double cur, int len)
{
try
{
String curStr = getSubStr(cur, len);
return new BigDecimal(curStr).doubleValue();
}
catch (NumberFormatException e) {}
return 0.0D;
}
private static String getSubStr(String cur, int len)
{
String curStr = cur;
if (len == 0) {
return “0”;
}
int indexLen = curStr.lastIndexOf(“.”);
int dicimalLen = curStr.length() - (indexLen + 1);
if (dicimalLen > len) {
curStr = curStr.substring(0, indexLen + len + 1);
} else {
for (int i = 0; i < len - dicimalLen; i++) {
curStr = curStr + "0";
}
}
return curStr;
}
public static String getTwoStr(String cur, int len)
{
try
{
Double curD = Double.valueOf(cur);
return getSubStr(curD, len);
}
catch (Exception e) {}
return “0”;
}
public static void main(String[] args)
{
String fileName = “TGS-AC1-V3.5.2.bin”;
String twoStr = getTwoStr(fileName, 3);
System.out.println(twoStr);
}
}