BigDecimal的加减乘除及比较大小

BigDecimal的加减乘除及比较大小BigDecimal的加减乘除及比较大小

大家好,又见面了,我是你们的朋友全栈君。

1 import java.math.BigDecimal;
 2 import static java.lang.System.out;
 3 public class BaseClass {
 4     public static void main(String[] args) {
 5         BigDecimal num1 = new BigDecimal("100");  
 6         BigDecimal num2 = new BigDecimal("50");  
 7         
 8         //加法
 9         BigDecimal result1 = num1.add(num2);
10         out.println("和    是   :  " + result1);
11         
12         //减法 
13         BigDecimal result2 = num1.subtract(num2);
14         out.println("差    是   :  " + result2);
15         
16         //乘法
17         BigDecimal result3 = num1.multiply(num2);
18         out.println("积    是   :  " + result3);
19         
20         //除法
21         BigDecimal result4 = num1.divide(num2);
22         out.println("商    是   :  " + result4);
23         
24         //比较
25         BigDecimal num = new BigDecimal("100");     //用做比较的值  
26         out.println(num1.compareTo(num2));            //大于 时,返回 1 
27         out.println(num.compareTo(num1));            //等于 时,返回 0  
28         out.println(num2.compareTo(num1));            //小于 时,返回 -1
29         
30         out.println(num1.min(num2));                //求两个数的最小值,返回小的数
31         out.println(num1.max(num2));                //求两个数的最大值,返回大的数
32         
33 //        compareTo方法比较时,不同于equals方法,需要两边都不为null,否则会报空指针异常,
34 //        源码如下
35 //        public int compareTo(BigDecimal val) {
36 //            // Quick path for equal scale and non-inflated case.
37 //            if (scale == val.scale) {
38 //                long xs = intCompact;
39 //                long ys = val.intCompact;
40 //                if (xs != INFLATED && ys != INFLATED)
41 //                    return xs != ys ? ((xs > ys) ? 1 : -1) : 0;
42 //            }
43 //            int xsign = this.signum();
44 //            int ysign = val.signum();
45 //            if (xsign != ysign)
46 //                return (xsign > ysign) ? 1 : -1;
47 //            if (xsign == 0)
48 //                return 0;
49 //            int cmp = compareMagnitude(val);
50 //            return (xsign > 0) ? cmp : -cmp;
51 //        }
52 
53 //        max/min方法源代码如下
54 //        public BigDecimal max(BigDecimal val) {
55 //            return (compareTo(val) >= 0 ? this : val);
56 //        }
57 //        public BigDecimal min(BigDecimal val) {
58 //            return (compareTo(val) <= 0 ? this : val);
59 //        }
60     }
61 }

转自:https://www.cnblogs.com/loginloading/p/6831762.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/106109.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • mysql中文乱码问题,phpmyadmin操作解决方法

    mysql中文乱码问题,phpmyadmin操作解决方法

  • 【解决方案】“‘javac’不是内部或外部命令,也不是可运行的程序或批处理文件”「建议收藏」

    【解决方案】“‘javac’不是内部或外部命令,也不是可运行的程序或批处理文件”「建议收藏」简述在学着使用Java的命令行来编译java文件的时候,遇到了这个问题Windows操作系统“‘javac’不是内部或外部命令,也不是可运行的程序或批处理文件”下面就讲讲解决方法解决过程根据探究的情况来看,这里其实是没有安装好(或者是安装了之后但是在环境变量上却没有设置好)第一步:在http://www.oracle.com/technetwork/java/ja…

  • Oracle PL/SQL编程之六: 把过程与函数说透「建议收藏」

    Oracle PL/SQL编程之六: 把过程与函数说透「建议收藏」Oracle PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)本篇主要内容如下:6.1 引言6.2 创建函数6.3 存储过程6.3.1 创建过程6.3.2 调用存储过程6.3.3 AUTHID6.3.4 PRAGMA AUTONOMOUS_TRANSACTION6.3.5 开发存储过程步骤

  • SMO算法笔记及个人理解

    SMO算法笔记及个人理解SMO算法介绍SMO算法是一种启发式算法,其基本思路是:如果所有变量的解都满足此优化问题的KKT条件,那么这个最优化问题的解就得到了。(KKT条件是该最优化问题的充分必要条件)。否则,选择两个变量,固定其他变量针对这两个变量构建一个二次规划问题。特点:将原始的二次规划问题分解为只含有两个变量的二次规划子问题,对子问题不断求解,使得所有的变量满足KKT条件包含两部分:1、求解两个变量二次规划的解析方法2、选择变量的启发式方法(1)第1个变量的选择:确定在当前的分类器中,违反K.

  • linux查看80端口占用情况_centos如何查看端口是否被占用

    linux查看80端口占用情况_centos如何查看端口是否被占用前言平常使用linux,我们经常需要查看哪个服务占用了哪个端口,接下来就为大家介绍了2种Linux查看端口占用情况可以使用lsof和netstat命令。1.lsof-i:端口号用

  • 教你如何搭建自己的直播服务器-简易

    教你如何搭建自己的直播服务器-简易使用背景:在项目中有没有遇见过要对接直播接口的需求?我想大家都是有的。但是怎么说呢,对接第三方的缺点也很明显,除去那不可避免的一些事故。最大的缺点就是要钱!!!要钱!!!要钱!!!对于我们公司来说

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号