舍入模式:

UP
向远离0的方向舍入
始终对非零舍弃部分前面的数字加 1。此舍入模式始终不会减少计算值的绝对值。
例如:1.6 → 2
      -1.6 → -2
      1.1 → 2
      -1.1 → -2

DOWN
向零方向舍入
此舍入模式始终不会增加计算值的绝对值。
例如:1.6 → 1
      -1.6 → -1
      1.1 → 1
      -1.1 → -1

CEILING
向正无穷方向舍入,此舍入模式始终不会减少计算值。
例如:1.6 → 2
      -1.6 → -1

FLOOR
向负无穷方向舍入,此舍入模式始终不会增加计算值。
例如:1.6 → 1
      -1.6 → -2

HALF_UP
向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入,此舍入模式就是通常学校里讲的四舍五入。
例如:1.6 → 2
      -1.6 → -2
      1.5 → 2
      -1.5 → -2

HALF_DOWN
向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入
例如:1.6 → 2
      -1.6 → -2
      1.4 → 1
      -1.4 → -1
      1.5 → 1
      -1.5 → -1

HALF_EVEN
向最接近数字方向舍入的舍入模式,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
如果舍弃部分左边的数字为奇数,则舍入行为同 RoundingMode.HALF_UP ;如果为偶数,则舍入行为同 RoundingMode.HALF_DOWN
例如:1.6 → 2
      -1.6 → -2
      2.5 → 2
      -2.5 → -2
      5.5 → 6
      -5.5 → -6

UNNECESSARY
计算结果是精确的,不需要舍入模式

数字的格式化:

 1     public static void main(String[] args) throws ParseException {
 2         // NumberFormat 逗号分隔
 3         double num1 = 20140426.193;
 4         NumberFormat format = NumberFormat.getInstance(Locale.CHINESE);
 5         System.out.println(format.format(num1)); // 20,140,426.193
 6 
 7         // NumberFormat 百分数
 8         num1 = 0.2;
 9         format = NumberFormat.getPercentInstance();
10         System.out.println(format.format(num1)); // 20%
11         
12         // NumberFormat 货币
13         num1 = 100;
14         format = NumberFormat.getCurrencyInstance(Locale.JAPAN);
15         System.out.println(format.format(num1)); // ¥100    
16         
17         // DecimalFormat #代表该位置上数字可有可无,0代表该位置的数字不存在的话补零
18         num1 = 20140426.193;
19         DecimalFormat f = new DecimalFormat();
20         f.applyPattern("#########.0000");
21         System.out.println(f.format(num1)); // 20140426.1930
22         
23         // DecimalFormat 默认四舍五入
24         f.applyPattern("#########.0");
25         System.out.println(f.format(num1)); // 220140426.2
26         
27         // DecimalFormat 每三位以逗号进行分隔
28         f.applyPattern(",###");
29         System.out.println(f.format(num1)); // 20,140,426
30         
31         // DecimalFormat 科学计数法
32         f.applyPattern("#.###E0");
33         System.out.println(f.format(num1)); // 2.014E7
34 
35         // 百分数
36         num1 = 0.15;
37         f.applyPattern("##%");
38         System.out.println(f.format(num1)); // 15%
39         
40         // 将格式嵌入文本
41         num1 = 15.2;
42         f.applyPattern("现在的时间是下午##点");
43         System.out.println(f.format(num1)); // 现在的时间是下午15点
44         
45         // 将带有格式化的字符数字复原
46         f.applyPattern("#,###.#");
47         System.out.println(f.parse("15.4"));
48         System.out.println(f.parse("201,415.46"));
49         
50         // 精度为2,向远离0的方向舍入
51         MathContext context = new MathContext(2, RoundingMode.UP);
52         BigDecimal num2 = new BigDecimal("1");
53         System.out.println(num2.divide(new BigDecimal(3), context));
54         // 精度为2,向零方向舍入 
55         context = new MathContext(2, RoundingMode.DOWN);
56         System.out.println(num2.divide(new BigDecimal(3), context));
57         // 精度为2,向正无穷方向舍入
58         context = new MathContext(2, RoundingMode.CEILING);
59         System.out.println(num2.divide(new BigDecimal(3), context));
60         // 精度为2,向负无穷方向舍入
61         context = new MathContext(2, RoundingMode.FLOOR);
62         System.out.println(num2.divide(new BigDecimal(3), context));
63         // 精度为2,向(距离)最近的一边舍入(四舍五入),如果两边(的距离)相等,向上舍入
64         context = new MathContext(2, RoundingMode.HALF_UP);
65         System.out.println(num2.divide(new BigDecimal(3), context));
66         // 精度为2,向(距离)最近的一边舍入,如果两边(的距离)相等,向下舍入
67         context = new MathContext(2, RoundingMode.HALF_UP);
68         System.out.println(num2.divide(new BigDecimal(3), context));
69         // 精度为2,向最接近数字方向舍入的舍入模式,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
70         context = new MathContext(2, RoundingMode.HALF_EVEN);
71         System.out.println(num2.divide(new BigDecimal(3), context));
72     }

Java 舍入模式 数字的格式化的更多相关文章

  1. Java中BigDecimal的8种舍入模式

    java.math.BigDecimal 不可变的.任意精度的有符号十进制数.BigDecimal 由任意精度的整数非标度值和32位的整数标度(scale)组成. 如果为零或正数,则标度是小数点后的位 ...

  2. Java中BigDecimal的8种舍入模式是怎样的

    Java中BigDecimal的8种舍入模式是怎样的?下面长沙欧柏泰克软件学院和大家一起来学习下吧:  java.math.BigDecimal 不可变的.任意精度的有符号十进制数.BigDecima ...

  3. Java中BigDecimal的舍入模式

    java.math.BigDecimal 不可变的.任意精度的有符号十进制数.BigDecimal 由任意精度的整数非标度值和32位的整数标度(scale)组成. 如果为零或正数,则标度是小数点后的位 ...

  4. Java大数类BigDecimal及八种舍入模式的介绍

    BigDecimal的引入 在利用Java编程语言开发银行.金融类等需要对数值进行高精度计算的软件时,我们经常使用BigDecimal和BigInteger这两个大数据类,而不是常见的int.long ...

  5. Java中数字的格式化输出

    Java中数字的格式化输出 double d = 345.678; String s = "hello!"; int i = 1234; //"%"表示进行格式 ...

  6. JSTL标签库中fmt标签,日期,数字的格式化

    首先介绍日期的格式化:(不要嫌多哦) JSTL格式化日期(本地化) 类似于数字和货币格式化,本地化环境还会影响生成日期和时间的方式. <%@ page pageEncoding="UT ...

  7. BigDecimal的精度舍入模式详解

    BigDecimal舍入模式介绍: 舍入模式在java.math.RoundingMode 里面: RoundingMode.CEILING :向正无限大方向舍入的舍入模式.如果结果为正,则舍入行为类 ...

  8. BigDecimal舍入模式使用及建议

    1. 八种舍入模式 此节内容参考于 https://my.oschina.net/sunchp/blog/670909. JDK1.5发布的枚举 RoundingMode 对 BigDecimal 的 ...

  9. BigDecimal 舍入模式(Rounding mode)介绍

    BigDecimal 舍入模式(Rounding mode)介绍 什么样的经历,才能领悟成为架构师? >>>   1 RoundingMode介绍 package java.math ...

随机推荐

  1. Poj3468-A Simple Problem with Integers(伸展树练练手)

    Description You have N integers, A1, A2, ... , AN. You need to deal with two kinds of operations. On ...

  2. shell中eval命令妙用——变量嵌套替换

    eval命令妙用--变量嵌套替换 eval命令在Linux下的应用非常广泛,在写脚本的时候遇到一个变量嵌套的问题,用eval迎刃而解,略试不爽啊. var1="hello" i=1 ...

  3. [转]Hulu 2013北京地区校招笔试题

    填空题: 1.中序遍历二叉树,结果为ABCDEFGH,后序遍历结果为ABEDCHGF,逆序遍历结果为? 2.对字符串HELL0_HULU中的字符进行二进制编码,使得字符串的编码长度尽可能短,最短长度为 ...

  4. 分析linux下的编译环境

    不论是windows下的程序,还是linux下的程序,开发环境都离不开三个目录:include.lib.bin,分别是头文件目录.库文件目录.运行文件目录.或许目录不叫这个名字,但却必不可少,除非你的 ...

  5. Linux环境 Mysql新建用户和数据库并授权

    测试环境:linux 和Mysql 5.5.35 一.新建用户 //登录Mysql@>mysql -u root -p@>密码//创建用户mysql> insert into mys ...

  6. linux hash_map

    在linux下的hash_map hash_map本身以前本身不属于标准库,是后来引入的.有两种可能:一种可能它被放在了stdext名空间里,那么你就要使用using namespace stdext ...

  7. 阿里云部署Docker(5)----管理和公布您的镜像

    出到这节,我在百度搜索了一下"阿里云部署Docker",突然发现怎么会有人跟我写的一样呢?哦,原来是其它博客系统的爬虫来抓取,然后也不会写转载自什么什么的.所以,我最终明确为什么那 ...

  8. Firebase远程更新应用

    能打造出色的应用不意味着一定能在商业上取得成功,两者之间还有许多工作要做,绝不能简单发布应用后就宣告“收工”.您需要能迅速根据用户反馈作出调整.测试新功能,以及向用户提供他们最关注的内容. Fireb ...

  9. asp.net 页面上传文件控件后台代码Request.Files获取不到

    今天开发中遇到页面文件上传控件选择了文件,而后台Request.Files.Count取值为0,之前开发中遇到过几次,老是忘掉,今天记下来. html: <input type="fi ...

  10. SQL日期形式转换

    在SQL Server中,有时存储在数据库中的日期格式和我们需要显示在页面上的格式不相同,我们需要转化成需要的格式. 特在此总结了一下常用的日期格式. --当前时间 SELECT GETDATE(); ...