服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - java中DecimalFormat四舍五入用法详解

java中DecimalFormat四舍五入用法详解

2021-04-08 14:58QIsMyQ Java教程

这篇文章主要为大家详细介绍了java中DecimalFormat四舍五入的用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。它可以支持不同类型的数,包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)这些内容的本地化。

下边先介绍下DecimalFormat的用法:

java" id="highlighter_619926">
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import java.text.*;
import java.util.*;
 
public class DecimalFormatDemo {
 public static void main(String args[]) {
   DecimalFormat df1 = new DecimalFormat("###,###.0000");//使用系统默认的格式
   System.out.println(df1.format(111111123456.12));
 
   Locale.setDefault(Locale.US);
   DecimalFormat df2= new DecimalFormat("###,###.0000");//使用美国的格式
   System.out.println(df2.format(111111123456.12));
 
//----------------------------also use applypattern------------------------------//
 
   DecimalFormat df3= new DecimalFormat();
   myformat3.applyPattern("##,###.000");
   System.out.println(df3.format(11112345.12345));
//-----------------控制指数输出-------------------------------------------------//
 
   DecimalFormat df4= new DecimalFormat();
   myformat4.applyPattern("0.000E0000");
   System.out.println(df4.format(10000));
   System.out.println(df4.format(12345678.345));
//------------------百分数的输出-------------------------------------------//
 
   DecimalFormat df5= null;
   try{
     df5= (DecimalFormat)NumberFormat.getPercentInstance();
   }catch(ClassCastException e){
   <span style="white-space:pre"> </span> System.err.println(e);
   }
   df5.applyPattern("00.0000%");
   System.out.println(df5.format(0.34567));
   System.out.println(df5.format(1.34567));   
 }
}

(1)对于数据的四舍五入

DecimalFormat 包含一组符号,对于各符号的含义解释如下:

0 一个数字

# 一个数字,不包括 0

. 小数的分隔符的占位符

, 分组分隔符的占位符

; 分隔格式。

- 缺省负数前缀。

% 乘以 100 和作为百分比显示

? 乘以 1000 和作为千进制货币符显示;用货币符号代替;如果双写,用国际货币符号代替。如果出现在一个模式中,用货币十进制分隔符代 替十进制分隔符。

X 前缀或后缀中使用的任何其它字符,用来引用前缀或后缀中的特殊字符。

例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
DecimalFormat df1 = new DecimalFormat("###0.00") ; //保留两位小数,如果不足两位小数则自动补零
System.out.println(df1.format(124.367));
System.out.println(df1.format(124.3));
     
DecimalFormat df2 = new DecimalFormat("###0.##") ; //保留两位小数,不足两位则不补零
System.out.println(df2.format(124.6));
System.out.println(df2.format(124));
     
DecimalFormat df3 = new DecimalFormat("000.000"); //保留三位小数,哪里不足位则补零
System.out.println(df3.format(24));
     
DecimalFormat df = new DecimalFormat("0.000E0000"); //指数
System.out.println(df.format(1234.56));
     
DecimalFormat nf = (DecimalFormat)NumberFormat.getPercentInstance(); //百分数
System.out.println(nf.format(0.476354));
nf.applyPattern("00.00%") ;
System.out.println(nf.format(0.476354));

运行结果:

?
1
2
3
4
5
6
7
8
124.37
124.30
124.6
124
024.000
1.235E0003
48%
47.64%

(2)对于读取并解析包含格式化的数字的字符串?解析支持包含在NumberFormat中。例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import java.util.Locale;
import java.text.NumberFormat;
import java.text.ParseException;
public class DecimalFormat5 {
public static void main(String args[]) {
  // 本地格式
  NumberFormat nf1 = NumberFormat.getInstance();
  Object obj1 = null;
  // 基于格式的解析
  try {
   obj1 = nf1.parse("1234,56");
  }
  catch (ParseException e1) {
   System.err.println(e1);
  }
  System.out.println(obj1);
  // 德国格式
  NumberFormat nf2 =NumberFormat.getInstance(Locale.GERMAN);
  Object obj2 = null;
  // 基于格式的解析
  try {
    obj2 = nf2.parse("1234,56");
  }
  catch (ParseException e2) {
    System.err.println(e2);
  }
  System.out.println(obj2);
  }
}

运行结果:

?
1
2
123456  //美国运行;被认为字符串
1234.56 //德国运行;被认为一个小数

(3)对于DecimalFormat和NumberFormat:

DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance 指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/u014704879/article/details/41479399

延伸 · 阅读

精彩推荐