NumberFormat.getInstance().format(1234.56)
但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。
另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:
importjava.text.DecimalFormat;
importjava.util.Locale;
publicclassDecimalFormat2{
publicstaticvoidmain(Stringargs[]){
//得到本地的缺省格式
DecimalFormatdf1=newDecimalFormat("####.000");
System.out.println(df1.format(1234.56));
//得到德国的格式
Locale.setDefault(Locale.GERMAN);
DecimalFormatdf2=newDecimalFormat("####.000");
System.out.println(df2.format(1234.56));
}
}
在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:
1234.560
1234,560
相似的,也可以控制指数形式的格式,例如:
importjava.text.DecimalFormat;
publicclassDecimalFormat3{
publicstaticvoidmain(Stringargs[]){
DecimalFormatdf=newDecimalFormat("0.000E0000");
System.out.println(df.format(1234.56));
}
}
输出:
1.235E0003
对于百分数:
importjava.text.NumberFormat;
publicclassDecimalFormat4{
publicstaticvoidmain(Stringargs[]){
NumberFormatnf=NumberFormat.getPercentInstance();
System.out.println(nf.format(0.47));
}
}
输出:
47%
至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在NumberFormat中。例如:
importjava.util.Locale;
importjava.text.NumberFormat;
importjava.text.ParseException;
publicclassDecimalFormat5{
publicstaticvoidmain(Stringargs[]){
//本地格式
NumberFormatnf1=NumberFormat.getInstance();
Objectobj1=null;
//基于格式的解析
try{

obj1=nf1.parse("1234,56");
}
catch(ParseExceptione1){
System.err.println(e1);
}
System.out.println(obj1);
//德国格式
NumberFormatnf2=NumberFormat.getInstance(Locale.GERMAN);
Objectobj2=null;
//基于格式的解析
try{
obj2=nf2.parse("1234,56");
}
catch(ParseExceptione2){
System.err.println(e2);
}
System.out.println(obj2);
}
}
这个例子分两部分,都是解析一个字符串:"1234,56"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:
123456
1234.56
换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。
3.4.DecimalFormat和NumberFormat的联系
在上面的例子中,DecimalFormat和NumberFormat都被使用了。DecimalFormat常用于获得很好的格式控制,而NumberFormat常用于指定不同于本地的地区。如何结合两个类呢?
答案围绕着这样的事实:DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch块包围强制转换以防转换不能正常工作(大概在非常不明显得情况下使用一个奇异的地区)。下面是一个这样的例子:
importjava.text.DecimalFormat;
importjava.text.NumberFormat;
importjava.util.Locale;
publicclassDecimalFormat6{
publicstaticvoidmain(Stringargs[]){
DecimalFormatdf=null;
//得到一个NumberFormat对象并
//强制转换为一个DecimalFormat对象
try{
df=(DecimalFormat)NumberFormat.getInstance(Locale.GERMAN);
}
catch(ClassCastExceptione){
System.err.println(e);
}
//设置格式模式
df.applyPattern("####.00000");
//formatanumber
System.out.println(df.format(1234.56));
}
}
getInstance()方法获得格式,然后调用applyPattern()方法设置格式模式,输出:
1234,56000
如果你不关心国际化,可以直接使用DecimalFormat。
其中v为未处理的double,scale为需求精度,返回需要小数位数的double
publicstaticdoubleround(doublev,intscale){
if(scale<0){
thrownewIllegalArgumentException(
"Thescalemustbeapositiveintegerorzero");
}
BigDecimalb=newBigDecimal(Double.toString(v));
BigDecimalone=newBigDecimal("1");
returnb.divide(one,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}