资讯   |   开发   |   选机中心   |   产品大全 | IBM | 惠普 | 联想 | 戴尔 | 苹果 | 神舟
更多: | 华硕 | 明基 | 方正 | 紫光 | TCL | 夏新 | 联宝 | 宏碁 | 七喜 | 长城 | 清华同方 | 海尔 | 三星 | 东芝 | 索尼 | 富士通 | LG | 技术 | ddnoon
当前位置:笔记本 > 编程开发 >
Advertisement
文章正文

在Java中如何确定浮点数的精度,例如按要求确定小数点后面的数字个数 _编程

类型:转载   责任编辑:asp.net   日期:2007/05/23


热门软件下载:


   
  • 中文文件下载失败的前因后果  
  • [引用] 既然有了Swing, 那为什么还要SWT?  
  • JDBC连接MYSQL  
  • struts中文的解决 filter的一种用法  
  • 21.3 用Ant来打包  
  • <<Eclipse开发指南>>的最终目录  
  • MyEclipse 下开发JSF教程  
  • 随机数的困惑(java.util.Random/Math.Random()  
  • WorkbenchAdvisor中的方法执行顺序  
  • Struts 的安装、配置与运行  
  • 页面导航:

    正文内容:
    //保留小数点后两位小数
    public double number2(double pdouble)
    {
      bigdecimal  bd=new  bigdecimal(pdouble);
      bigdecimal  bd1=bd.setscale(2,bd.round_half_up);
      pdouble=bd1.doublevalue();
      long  ll = double.doubletolongbits(pdouble);
      return pdouble;
    }
    格式化输出数字
    翻译:cherami
    email:cherami@163.net
    原文:http://developer.java.sun.com/developer/techtips/2000/tt0411.html
    * 格式化输出数字
    格式化输出数字
    有时我们需要控制输出的数字的格式,如何使用java的类库做到这个呢?
    也许你不关心格式,但是你需要关心你的程序可以在全世界通用,像下面的这样一个简单的语句是依赖地区的:
      system.out.println(1234.56);
    在美国,"." 是小数点,但在其它地方就不一定了。如何处理这个呢?

    java.text 包中的一些包可以处理这类问题。下面的简单范例使用那些类解决上面提出的问题:

      import java.text.numberformat;

      import java.util.locale;

      public class decimalformat1 {

      public static void main(string args[]) {

       // 得到本地的缺省格式

       numberformat nf1 = numberformat.getinstance();

       system.out.println(nf1.format(1234.56));

       // 得到德国的格式

       numberformat nf2 =

       numberformat.getinstance(locale.german);

       system.out.println(nf2.format(1234.56));

      }

      }

    如果你在美国,运行程序后输出:

      1,234.56

      1.234,56

    换句话说,在不同的地方使用不同的习惯表示数字。

    numberformat.getinstance()方法返回numberformat的一个实例(实际上是numberformat具体的一个子类,例如decimalformat), 这适合根据本地设置格式化一个数字。你也可以使用非缺省的地区设置,例如德国。然后格式化方法根据特定的地区规则格式化数字。这个程序也可以使用一个简单的形式:

      numberformat.getinstance().format(1234.56)

    但是保存一个格式然后重用更加有效。国际化是格式化数字时的一个大问题。

    另一个是对格式的有效控制,例如指定小数部分的位数,下面是解决这个问题的一个简单例子:

      import java.text.decimalformat;

      import java.util.locale;

      public class decimalformat2 {

      public static void main(string args[]) {

       // 得到本地的缺省格式

       decimalformat df1 = new decimalformat("####.000");

       system.out.println(df1.format(1234.56));

       // 得到德国的格式

       locale.setdefault(locale.german);

       decimalformat df2 = new decimalformat("####.000");

       system.out.println(df2.format(1234.56));

      }

      }

    在这个例子中设置了数字的格式,使用像"####.000"的符号。这个模式意味着在小数点前有四个数字,如果不够就空着,小数点后有三位数字,不足用0补齐。程序的输出:

      1234.560

      1234,560

    相似的,也可以控制指数形式的格式,例如:

      import java.text.decimalformat;

      public class decimalformat3 {

      public static void main(string args[]) {

       decimalformat df = new decimalformat("0.000e0000");

       system.out.println(df.format(1234.56));

      }

      }

    输出:

      1.235e0003

    对于百分数:

      import java.text.numberformat;

      public class decimalformat4 {

      public static void main(string args[]) {

       numberformat nf = numberformat.getpercentinstance();

       system.out.println(nf.format(0.47));

      }

      }

    输出:

      47%

    至此,你已经看到了格式化数字的几个不同的技术。另一方面,如何读取并解析包含格式化的数字的字符串?解析支持包含在numberformat中。例如:

      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);

      }

      }

    这个例子分两部分,都是解析一个字符串:"1234,56"。第一部分使用本地格式解析,第二部分使用德国格式解析。当程序在美国运行,结果是:

      123456

      1234.56

    换句话说,"1234,56"在美国被认为是一个巨大的整数"123456"而在德国被认为是一个小数"1234.56"。

    还有格式化讨论的最后一个问题。在上面的例子中, decimalformat 和 numberformat 都被使用了。decimalformat 常用于获得很好的格式控制,而numberformat 常用于指定不同于本地的地区。如何结合两个类呢?

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

      import java.text.decimalformat;

      import java.text.numberformat;

      import java.util.locale;

      public class decimalformat6 {

      public static void main(string args[]) {

       decimalformat df = null;

       // 得到一个numberformat 对象并

       // 强制转换为一个 decimalformat 对象

       try {

       df = (decimalformat)

       numberformat.getinstance(locale.german);

       }

       catch (classcastexception e) {

       system.err.println(e);

       }

       // 设置格式模式

       df.applypattern("####.00000");

       // format a number

       system.out.println(df.format(1234.56));

      }
      }

    getinstance() 方法获得格式,然后调用applypattern()方法设置格式模式,输出:

      1234,56000

    如果你不关心国际化,可以直接使用decimalformat 。

     

     
    热门推荐笔记本: NEC笔记本
    相关文章:
    webmaster:popbb@126.com   最佳浏览:1024X768 MSIE
    ©2007 popbb.net All Rights Reserved