此为学习笔记,若有侵权请联系我,谢谢!!!

  • 构造器描述
  • BigDecimal(int) 创建一个具有参数所指定整数值的对象。
  • BigDecimal(double) 创建一个具有参数所指定双精度值的对象。 //不推荐使用
  • BigDecimal(long) 创建一个具有参数所指定长整数值的对象。
  • BigDecimal(String) 创建一个具有参数所指定以字符串表示的数值的对象。//推荐使用
  • 方法描述
  • add(BigDecimal) BigDecimal对象中的值相加,然后返回这个对象。
  • subtract(BigDecimal) BigDecimal对象中的值相减,然后返回这个对象。
  • multiply(BigDecimal) BigDecimal对象中的值相乘,然后返回这个对象。
  • divide(BigDecimal) BigDecimal对象中的值相除,然后返回这个对象。
  • toString() 将BigDecimal对象的数值转换成字符串。
  • doubleValue() 将BigDecimal对象中的值以双精度数返回。
  • floatValue() 将BigDecimal对象中的值以单精度数返回。
  • longValue() 将BigDecimal对象中的值以长整数返回。
  • intValue() 将BigDecimal对象中的值以整数返回。
  • 八种舍入模式解释如下(除法)
  • 八种舍入模式解释如下

1、ROUND_UP舍入远离零的舍入模式。在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。
注意,此舍入模式始终不会减少计算值的大小。

2、ROUND_DOWN
接近零的舍入模式。在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。
注意,此舍入模式始终不会增加计算值的大小。

3、ROUND_CEILING
接近正无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;如果为负,则舍入行为与 ROUND_DOWN 相同。
注意,此舍入模式始终不会减少计算值。

4、ROUND_FLOOR
接近负无穷大的舍入模式。如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;如果为负,则舍入行为与 ROUND_UP 相同。
注意,此舍入模式始终不会增加计算值。

5、ROUND_HALF_UP
向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。
注意,这是我们大多数人在小学时就学过的舍入模式(四舍五入)。

6、ROUND_HALF_DOWN
向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。
如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。

7、ROUND_HALF_EVEN
向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;
如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。
注意,在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。
此舍入模式也称为“银行家舍入法”,主要在美国使用。四舍六入,五分两种情况。
如果前一位为奇数,则入位,否则舍去。
以下例子为保留小数点1位,那么这种舍入方式下的结果。
1.15>1.2 1.25>1.2

8、ROUND_UNNECESSARY
断言请求的操作具有精确的结果,因此不需要舍入。如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。

 @Testpublic void add(){BigDecimal addOne = new BigDecimal("111");BigDecimal addTwo = new BigDecimal("222");BigDecimal add = addOne.add(addTwo);System.out.println(add);}

 @Testpublic void subtract(){BigDecimal subtractOne = new BigDecimal("333.33");BigDecimal subtractTwo = new BigDecimal("111.22");BigDecimal subtract = subtractOne.subtract(subtractTwo);System.out.println(subtract);}

@Testpublic void multiply(){BigDecimal multiplyOne = new BigDecimal("11.123");BigDecimal multiplyTwo = new BigDecimal("22.234");BigDecimal multiply = multiplyOne.multiply(multiplyTwo);System.out.println(multiply);}

    @Testpublic void divide(){BigDecimal divideOne = new BigDecimal("33.234");BigDecimal divideTwo = new BigDecimal("11");BigDecimal divide = divideOne.divide(divideTwo,5,BigDecimal.ROUND_HALF_UP);System.out.println(divide);//1 ROUND_UP舍入远离零的舍入模式BigDecimal round_up = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_UP);System.out.println("舍入远离零的舍入模式"+round_up);//2、ROUND_DOWN 接近零的舍入模式BigDecimal round_down = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_DOWN);System.out.println("接近零的舍入模式"+round_down);//3、ROUND_CEILING 接近正无穷大的舍入模式BigDecimal round_celing = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_CEILING);System.out.println("接近正无穷大的舍入模式"+round_celing);//4、ROUND_FLOOR 接近负无穷大的舍入模式BigDecimal round_floor = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_FLOOR);System.out.println("接近负无穷大的舍入模式"+round_floor);//5、ROUND_HALF_UP 向“最接近的”数字舍入 四舍五入BigDecimal round_helf_up = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_HALF_UP);System.out.println("四舍五入"+round_helf_up);//6、ROUND_HALF_DOWN 向“最接近的”数字舍入 五舍六入BigDecimal round_half_down = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_HALF_DOWN);System.out.println("五舍六入"+round_half_down);//7、ROUND_HALF_EVEN 向“最接近的”数字舍入 如果是奇数ROUND_HALF_UP相同 如果是偶数 和ROUND_HALF_DOWN 相同BigDecimal even = divideOne.divide(divideTwo, 5, BigDecimal.ROUND_HALF_EVEN);System.out.println("如果是奇数ROUND_HALF_UP相同 如果是偶数 和ROUND_HALF_DOWN 相同"+even);//8、ROUND_UNNECESSARY 断言请求的操作具有精确的结果 无线小数会报错BigDecimal divideOne1 = new BigDecimal("30");BigDecimal divideTwo1 = new BigDecimal("20");BigDecimal unecessary = divideOne1.divide(divideTwo1, 5, BigDecimal.ROUND_UNNECESSARY);System.out.println("断言求精确结果"+unecessary);}

bigDecimal学习笔记_隋小白相关推荐

  1. 学习笔记_关于switch在whlie中无限循环的解决办法_C语言

    学习笔记_关于switch在whlie中无限循环的解决办法_C语言 今天在做作业的时候突然发现一个问题 #include<stdio.h> int main() {int a;while( ...

  2. oracle11g中用asmlib配置磁盘组,ASM学习笔记_配置ASMLIB磁盘组

    ASM学习笔记_配置ASMLIB磁盘组 目录 1 ASMLIB Introduction 2 虚拟机添加一个共享磁盘(块设备) 3 下载,安装ASMLIB 4 配置,使用ASMLib 磁盘组 #### ...

  3. MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结

    MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结 一.VARCHAR存储和行长度限制 1.VARCHAR(N)中,N指的是字符的长度,VARCHAR类型最大支持65535,指的是 ...

  4. 系统架构师学习笔记_第六章(下)_连载

    系统架构师学习笔记_第六章(下)_连载 6.3 基于 UML 的软件开发过程 6.3.1  开发过程概述 UML 是独立于软件开发过程的,能够在几乎任何一种软件开发过程中使用.迭代的渐进式软件开发过程 ...

  5. Go学习笔记_环境搭建

    Go学习笔记_环境搭建 Go背景知识 go的特点(官网): Build fast, reliable, and efficient software at scale- Go is an open s ...

  6. c语言用位运算将一个数清零,C语言学习笔记_位运算

    C语言学习笔记_位运算 知识点记录 基本位运算 按位与:全1为1,见0为0:与1相与无变化,与0相与变为0:可用于特定位清零 按位或:见1为1,全0为0:与1相或变为1,与0相或无变化:可用于特定位置 ...

  7. 数字IC设计学习笔记_静态时序分析STA_ STA基本概念

    数字IC设计学习笔记 STA基本概念 1. STA基本概念 2. 时序弧概念 Timing Arc 3. 建立时间和保持时间概念 4. 时序路径概念Timing Path 5. 时钟域概念clock ...

  8. 模电学习笔记_双极型晶体管及其放大电路(4)

    前置:模电学习笔记_双极型晶体管及其放大电路(3) 一.基本知识点 2.5 晶体管单管放大电路的三种基本组态 2.5.1 共集放大电路(射极输出器.射极跟随器) 1.主要特点:高输入阻抗,低输出阻抗, ...

  9. 模电学习笔记_双极型晶体管及其放大电路(2)

    前置:双极型晶体管及其放大电路(1) 一.基本知识点 补充:集成电路中元器件的特点 1.单个元件的参数精度不高,且受温度影响较大,但参数对称性及温度对称性较好.批量间差异较大 2.集成电路工艺制造出的 ...

最新文章

  1. 英特尔在移动市场另辟蹊径
  2. WIN2008系统的IIS7.0配置REWRITE伪静态环境
  3. 公司正式宣布创业失败!
  4. [BZOJ3992]序列统计
  5. 编程中的移位运算符简单解释
  6. 如何在python中识别未知的日期时区时区
  7. Hello Rails
  8. Zend Framework学习之验证ing
  9. oracle上机题库_Oracle OCP认证考试IZ0-053题库共712题数据库(带中文解析)
  10. 开发者从应用程序商店难以赚到真金白银
  11. 【antd 3.x】upload上传组件预览pdf格式文件和下载ofd格式文件
  12. 如何将mac中的资料拷贝到U盘,移动硬盘(实用!!!)
  13. 一个强迫症的电脑下(软件篇)
  14. 如何克隆LINUX硬盘:4种方法
  15. 4816: [Sdoi2017]数字表格
  16. LeetCode #1088. Confusing Number II
  17. 攻防世界web做题步骤
  18. javascript招式总结
  19. Android 饼形图
  20. 云止水中,但是风却不能停泊在海上

热门文章

  1. python3编译成pyc文件
  2. 软工视频到底在讲什么?
  3. java怎么做3d可视化图形
  4. 什么是意志力?如何提高意志力?
  5. Golang 字符串拼接
  6. MySQL数据库的存储引擎
  7. 法拉科机器人接头_图解FANUC机器人I/O信号板接口定义与拆装
  8. 编译实验 lr c语言代码,编译原理-实验5-LR(1)分析法
  9. brpc源码解析(四)—— Bthread机制
  10. 学习记录466@Java Calender类、TimeUnit类以及 ScheduledExecutorService实现定时任务