博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于BigDecimal的四舍五入和截断 (转)
阅读量:5255 次
发布时间:2019-06-14

本文共 980 字,大约阅读时间需要 3 分钟。

关于BigDecimal的四舍五入和截断_canna宝贝_新浪博客 http://blog.sina.com.cn/s/blog_4836510801000axz.html

关于四舍五入:

ROUND_HALF_UP: 遇到.5的情况时往上近似,例: 1.5 ->;2
ROUND_HALF_DOWN : 遇到.5的情况时往下近似,例: 1.5 ->;1

BigDecimal a = new BigDecimal(1.5); System.out.println("down="+a.setScale(0,BigDecimal.ROUND_HALF_DOWN)+"\tup="+a.setScale

(0,BigDecimal.ROUND_HALF_UP));

结果:down=1  up=2

 

关于BigDecimal的截断:

BigDecimal aa = new BigDecimal(99.999);
aa=aa.setScale(2,BigDecimal.ROUND_DOWN);
结果:aa=99.99,即在小数点后两位处截断。

 

其他参数说明

  ROUND_CEILING    
  如果BigDecimal是正的,则做ROUND_UP操作;

  如果为负,则做ROUND_DOWN操作。       

  ROUND_FLOOR    
  如果BigDecimal为正,则作ROUND_UP;

  如果为负,则作ROUND_DOWN。    

  ROUND_HALF_DOWN  
  若舍弃部分> 0.5,则作ROUND_UP;

  否则,作ROUND_DOWN。    

  ROUND_HALF_EVEN    
  如果舍弃部分左边的数字为奇数,则作ROUND_HALF_UP;

  如果它为偶数,则作ROUND_HALF_DOWN。    

  ROUND_HALF_UP    
  若舍弃部分>=.5,则作ROUND_UP;否则作ROUND_DOWN。    
  ROUND_UNNECESSARY    
  该“伪舍入模式”实际是指明所要求的操作必须是精确的,

  因此不需要舍入操作。    

  ROUND_UP    
  总是在非0舍弃小数(即截断)之前增加数字。

 (其实就是只要不是0,就进一位的意思)

  ROUND_DOWN    
  从不在舍弃(即截断)的小数之前增加数字(其实就是截断的意思)。

转载于:https://www.cnblogs.com/ganymede/p/4059703.html

你可能感兴趣的文章
beautifulsoup用法1
查看>>
Use AUTO Mode with FOR XML (SQL Server 2012) Multiple Table
查看>>
POJ 1637 Sightseeing tour ★混合图欧拉回路
查看>>
ES6新特性概览
查看>>
线性回归代码实现(matlab)
查看>>
mysql的常用命令
查看>>
正则表达式
查看>>
PCL常见错误集锦
查看>>
windows 8,微软创新之路
查看>>
泛型参数转换的问题
查看>>
Oracle DUL/AUL/ODU 工具说明
查看>>
闭包机制
查看>>
android:wifi
查看>>
jquery做的滑动按钮开关
查看>>
DevExpress控件之主题
查看>>
一行代码解决各种IE兼容问题,IE6,IE7,IE8,IE9,IE10
查看>>
如何在Window上使用Git
查看>>
读书笔记:培训师必修课
查看>>
Jsp/html页面删除前进行删除提示
查看>>
事务隔离级别区分,未提交读,提交读,可重复读
查看>>