Java常用类库——数字格式化(NumberFormat)与大数操作(BigIntger、BigDecimal类)...

学习目标

可以使用NumberFormat类进行本地化数字显示。
可以使用DecimalFormat指定格式化模板。
可以使用BigInteger操作大整数。
可以使用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可以指定好四舍五入的精确位置。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值