java-两个long类型数据转换为int并且相除获得百分比

在数据库里通过count()函数查到了两个数据,进行相除的时候爆出异常:java.lang.long can not be cast to java.lang.Integer

在网上查了资料发现是数据库的问题,查出来的是long类型,而long类型是不能直接相除的。

但是又不能直接转换为integer,因为integer和long都是直接继承于父类Number类型,直接转换会报上述异常。

那就从Number下手。

((java.lang.Number) goods.get("favourableCommentNum")).intValue()可以把long类型转换为一个int数据

((java.lang.Number) goods.get("favourableCommentNum")).doubleValue()可以把long类型转换为一个double数据,因为要计算百分比,就需要转换成double类型。

DecimalFormat df = new DecimalFormat("0%");

df.format(((java.lang.Number) goods.get("favourableCommentNum")).intValue()/ ((java.lang.Number) goods.get("commentNum")).doubleValue())就可以算出不带小数点的百分比

DecimalFormat df1 = new DecimalFormat("0.00%");

df1.format(((java.lang.Number) goods.get("favourableCommentNum")).intValue()/ ((java.lang.Number) goods.get("commentNum")).doubleValue())计算出的是带小数点后两位的百分比

java-两个long类型数据转换为int并且相除获得百分比_第1张图片

你可能感兴趣的:(java)