浮点型数据精确计算

**
 * 参考:https://www.jianshu.com/p/c3c6cf0dce66
 * @author zls
 * @date 2019/8/20
 */
public class ComputedDemo {
    public static void main(String[] args) {
        // JAVA的double型数据不能进行精确计算
        double n = 1.01 + 2.13;
        System.out.println("n = " + n); // n = 3.1399999999999997


        // double型数值在整数部分超过7位时就自动转化为科学记数法表示。
        System.out.println(12345678.0); // 1.2345678E7


        /**
         * 浮点型数据运算:
         * BigDecimal是用来精确计算的
         * 缺点:使用BigDecimal的坏处是性能比double和float差,在处理庞大,复杂的运算时尤为明显,因根据实际需求决定使用哪种类型。
         */


        BigDecimal x = new BigDecimal("2");
//        BigDecimal x = BigDecimal.valueOf(2);
        BigDecimal y = new BigDecimal("3");
        BigDecimal z = x.add(y);
        System.out.println("相加:" + z); // 5

        z = x.subtract(y);
        System.out.println("相减:" + z); // -1

        z = x.multiply(y);
        System.out.println("相乘:" + z); // 6

        z = x.divide(y, BigDecimal.ROUND_HALF_UP);
        System.out.println("相除:" + z); // 1

        z = x.divide(y, 3, BigDecimal.ROUND_HALF_UP);
        System.out.println("设置精度:" + z); // 0.667

        BigDecimal a = new BigDecimal("1");
        BigDecimal b = new BigDecimal("2");
        BigDecimal c = new BigDecimal("1");
        int result1 = a.compareTo(b);
        int result2 = a.compareTo(c);
        int result3 = b.compareTo(a);
        System.out.println(result1);
        System.out.println(result2);
        System.out.println(result3);
        // -1、0、1,即左边比右边数大,返回1,相等返回0,比右边小返回-1。
    }
}

 

转载于:https://www.cnblogs.com/shiyun32/p/11382226.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值