zoukankan      html  css  js  c++  java
  • 【摘抄】Java常用类库——数字格式化(NumberFormat)与大数操作(BigIntger、BigDecimal类)

    NumberFormat类

    NumberFormat表示数字的格式化类,即:可以按照本地的风格习惯进行数字的显示。
    此类的定义如下:
    public abstract class NumberFormat extends Format
    NO           方法                                                                                   类型                   描述
    1          public static Locale[] getAvailableLocales()                           普通           返回所有语言环境的数组
    2          public static final NumberFormat getInstance()                     普通           返回当前默认语言环境的数字格式
    3          public static NumberFormat  getInstance(Locale inLocale)   普通           返回指定语言环境的数字格式
    4          public static final NumberFormat getCurrencyInstance()       普通           返回当前默认环境的货币格式
    5          public static NumberFormat getCurrencyInstance(Locale inLocale)       返回指定语言环境的数据格式
    查看API如下:
     
    方法如下:
    等等,具体开发使用时查找API即可。
    MessageFormat、DateFormat、NumberFormat是Format三个常用的子类,如果想进一步完成一个好的国际化程序,则肯定需要同时使用这样三个类完成,根据不同的国家显示日期,或者显示货币的形式。
     此类还是在java.text包中,所以直接导入此包即可。
    程序代码示例如下:
    import java.text.* ;  
    public class NumberFormatDemo01{  
        public static void main(String args[]){  
            NumberFormat nf = null ;        // 声明一个NumberFormat对象  
            nf = NumberFormat.getInstance() ;   // 得到默认的数字格式化显示  
            System.out.println("格式化之后的数字:" + nf.format(10000000)) ;  
            System.out.println("格式化之后的数字:" + nf.format(1000.345)) ;  
        }  
    };  

    DecimalFormat的基本使用

    是NumberFormat类的子类。可以直接指定其显示的模板。
    DecimalFormat也是Format的一个子类,主要的作用是用来格式化数字使用,当然,在格式化数字的时候要比直接使用NumberFormat更加方便,因为可以直接指定按用户自定义的方式进行格式化操作,与之前的SimpleDateFormat类似,如果要想进行自定义格式化操作,则必须指定格式化操作的模板。
    查找API 如下:
    格式化模板如下所示:
    程序代码示例如下:
    import java.text.* ;  
    class FormatDemo{  
        public void format1(String pattern,double value){   // 此方法专门用于完成数字的格式化显示  
            DecimalFormat df = null ;           // 声明一个DecimalFormat类的对象  
            df = new DecimalFormat(pattern) ;   // 实例化对象,传入模板  
            String str = df.format(value) ;     // 格式化数字  
            System.out.println("使用" + pattern  
                + "格式化数字" + value + ":" + str) ;  
        }  
    };  
    public class NumberFormatDemo02{  
        public static void main(String args[]){  
            FormatDemo demo = new FormatDemo() ;    // 格式化对象的类  
            demo.format1("###,###.###",111222.34567) ;  
            demo.format1("000,000.000",11222.34567) ;  
            demo.format1("###,###.###¥",111222.34567) ;  
            demo.format1("000,000.000¥",11222.34567) ;  
            demo.format1("##.###%",0.345678) ;  
            demo.format1("00.###%",0.0345678) ;  
            demo.format1("###.###u2030",0.345678) ;  
        }  
    };  
     
    大数操作:正常情况下,一个整数最多只能放在long类型之中,但是现在有如下的一个数字:
    1111111111111111111111111111111111111111111111111111111111111
    根本是无法保存的,所以为了解决这样的问题,在java中引入了两个大数的操作类:
    操作整型:BigInteger
    操作小数:BigDecimal

    BigInteger

    如果在操作的时候一个整型数据已经超过了整数的最大长度long的话,则此数据就无法装入,所以此时就要使用BigInteger类进行操作。
    NO      方法                                                          类型      描述
    1         public BigInteger(String val)                     构造      将一个字符串变为BigInteger类型的数据。
    2         public BigInteger add(BigInteger val)       普通      加法
    3         public BigInteger subtract(BigInteger val) 普通     减法
    4         public BigInteger multiply(BigInteger val)  普通     乘法
    5         public BigInteger divide(BigInteger val)     普通     除法
    6         public BigInteger max(BigInteger val)       普通      返回两个大数字中的最大值
    7         public BigInteger min(BigInteger val)       普通      返回两个大数字中的最小值
    8         public BigInteger[] divideAndRemainder(BigInteger val)
                  普通      除法操作,数组的第一个元素为除法的商,第二个元素为除法的余数。
    BigInteger 是在java.math包中定义的
    程序实例如下:
    import java.math.* ;  
    class MyMath{  
        public static double add(double d1,double d2){      // 进行加法计算  
            BigDecimal b1 = new BigDecimal(d1) ;  
            BigDecimal b2 = new BigDecimal(d2) ;  
            return b1.add(b2).doubleValue() ;  
        }  
        public static double sub(double d1,double d2){      // 进行减法计算  
            BigDecimal b1 = new BigDecimal(d1) ;  
            BigDecimal b2 = new BigDecimal(d2) ;  
            return b1.subtract(b2).doubleValue() ;  
        }  
        public static double mul(double d1,double d2){      // 进行乘法计算  
            BigDecimal b1 = new BigDecimal(d1) ;  
            BigDecimal b2 = new BigDecimal(d2) ;  
            return b1.multiply(b2).doubleValue() ;  
        }  
        public static double div(double d1,double d2,int len){      // 进行乘法计算  
            BigDecimal b1 = new BigDecimal(d1) ;  
            BigDecimal b2 = new BigDecimal(d2) ;  
            return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;  
        }  
        public static double round(double d,int len){   // 进行四舍五入  
            BigDecimal b1 = new BigDecimal(d) ;  
            BigDecimal b2 = new BigDecimal(1) ;  
            return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;  
        }  
    };  
      
    public class BigDecimalDemo01{  
        public static void main(String args[]){  
            System.out.println("加法运算:" + MyMath.round(MyMath.add(10.345,3.333),1)) ;  
            System.out.println("减法运算:" + MyMath.round(MyMath.sub(10.345,3.333),3)) ;  
            System.out.println("乘法运算:" + MyMath.round(MyMath.mul(10.345,3.333),2)) ;  
            System.out.println("除法运算:" + MyMath.div(10.345,3.333,3)) ;  
        }  
    };  

     

    BigDecimal

    对于不需要任何准确计算精度的程序可以直接使用float或double完成,但是如果需要精确计算的结果,则必须使用BigDecimal类。
    具体方法如下:
    具体的使用方法与BigInteger类似。程序代码示例如下:
    import java.math.BigInteger ;  
    public class BigIntegerDemo01{  
        public static void main(String args[]){  
            BigInteger bi1 = new BigInteger("123456789") ;  // 声明BigInteger对象  
            BigInteger bi2 = new BigInteger("987654321") ;  // 声明BigInteger对象  
            System.out.println("加法操作:" + bi2.add(bi1)) ;    // 加法操作  
            System.out.println("减法操作:" + bi2.subtract(bi1)) ;   // 减法操作  
            System.out.println("乘法操作:" + bi2.multiply(bi1)) ;   // 乘法操作  
            System.out.println("除法操作:" + bi2.divide(bi1)) ; // 除法操作  
            System.out.println("最大数:" + bi2.max(bi1)) ;  // 求出最大数  
            System.out.println("最小数:" + bi2.min(bi1)) ;  // 求出最小数  
            BigInteger result[] = bi2.divideAndRemainder(bi1) ; // 求出余数的除法操作  
            System.out.println("商是:" + result[0] +   
                ";余数是:" + result[1]) ;  
        }  
    };


    总结:
    1、NumberFormat完成的功能只是根据区域不同固定的数字显示格式。
    2、DecimalFormat是可以由由用户自己指定其显示的格式,所以比较好用。
    3、虽然在开发中很少遇到大数的情况,但是有可能遇到的。
    4、使用BigDecimal可以指定好四舍五入的精确位置。
     
     
    本文转至:https://blog.csdn.net/u013087513/article/details/51832000 
  • 相关阅读:
    Octave Tutorial(《Machine Learning》)之第二课《数据移动》
    Octave Tutorial(《Machine Learning》)之第一课《数据表示和存储》
    《Machine Learning》系列学习笔记之第三周
    《Machine Learning》系列学习笔记之第二周
    《Machine Learning》系列学习笔记之第一周
    如何下载图片新闻并将其写入文件
    openmv之ApriTag
    opencv学习记录之阈值处理
    opencv学习记录之几何变换
    opencv学习记录之alpha通道
  • 原文地址:https://www.cnblogs.com/YuzL/p/9159164.html
Copyright © 2011-2022 走看看