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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MultiSet_multilayered

    MultiSet_multilayeredGuava引进了JDK里没有的,但是非常有用的一些新的集合类型。所有这些新集合类型都能和JDK里的集合平滑集成。Guava集合非常精准地实现了JDK定义的接口。Guava中定义的新集合有:Multi

    2022年8月5日
    3
  • Linux安装软件命令&&快捷键

    安装软件命令(1)、rpm和yum命令介绍rpm:rpm是由RedHat公司开发的一种软件包管理方式,使用rpm我们可以方便的进行软件的安装、查询、卸载等工作,但是使用rpm命令安装rpm软件包,不能自己解决软件包之间的依赖性问题,需要自己一个一个去安装依赖的软件包。yum:Yum(全称为YellowdogUpdater,Modified):是一…

    2022年4月15日
    80
  • TensorFlow加载cifar10数据集

    TensorFlow加载cifar10数据集加载cifar10数据集cifar10_dir=’C:/Users/1/.keras/datasets/cifar-10-batches-py'(train_images,train_labels),(test_images,test_labels)=load_data(cifar10_dir)注意:在官网下好cifar10数据集后将其解压成下面形式load_local_cifar10.pyfrom__future__importabsolute_importfrom_

    2022年6月22日
    49
  • (超级详细版)利用ThinkPHP3.2.3+PHPExcel实现将表格数据导入到数据库

    (超级详细版)利用ThinkPHP3.2.3+PHPExcel实现将表格数据导入到数据库

    2021年10月21日
    37
  • N3K跨网段流量异常

    N3K跨网段流量异常

    2021年9月14日
    39
  • Typora下载和简单使用教程

    Typora下载和简单使用教程Typora下载Typora官网下载地址根据自己的电脑选择不同的版本,我用的是Windows64位的系统的就选择DownloadBeta(×64)下载完Typora以后我们就可以使用markdown了。Typora的学习1.标题数量 标题级数 快捷键 一个#加空格加内容 一级标题 Ctrl+1 两个#加空格加内容 二级标题 Ctrl+2 三个#加空格加内容 三级标题 Ctrl+3 以此类..

    2022年5月19日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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