在业务编码中,我们避免不了业务数值的运算,但是金钱类的计算为了不丢失精度,我们都是采用BigDecimal。那么问题来了,诸多的加减乘除,我们需要不断的使用add、multiply等去做运算,可读性差一不小心还会出错!!所以可以使用Aviator 表达式,直接上代码!!
1、使用Aviator 需要导入包
<dependency>
<groupId>com.googlecode.aviator</groupId>
<artifactId>aviator</artifactId>
<version>3.3.0</version>
</dependency>
2、简单的操作以及基础不再赘述
详细的可以参考 https://blog.csdn.net/keda8997110/article/details/50782848
(个人感觉这个博主写的挺全的)
3、个人感觉使用起来比较方便的自定义方法
以银行利息计算公式为例
利息=本金×年数×年利率+本金×零头天数×日利率
–> 利息=本金×(年数×年利率+零头天数×日利率)
BigDecimal rateSum = (BigDecimal) AviatorEvaluator.execute(
"本金*(年数*年利率+零头天数*日利率)",
MapUtil.array2Map(new Object[][]{
{"本金", order.getMoneySum()},
{"年数", order.getYearCount()},
{"年利率", order.getYearRate()},
{"零头天数", order.getDaySum()},
{"日利率", order.getDailyRate()}
})
);
public class MapUtil {
public static Map<String, Object> array2Map(Object[][] params) {
Map rec = new LinkedHashMap();
for (Object[] os : params) {
rec.put(os[0], os[1]);
}
return rec;
}
}
注 里面的括号 别一不小心用了 中文的 此乃低级错误!*
此乃神器,特此记录!