Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。雙精度浮點型變量double能夠處理16位有效數。java
在實際應用中,須要對更大或者更小的數進行運算和處理。float和double只能用來作科學計算或者是工程計算,在商業計算中要用java.math.BigDecimal。ide
BigDecimal所建立的是對象,咱們不能使用傳統的+、-、*、/等算術運算符直接對其對象進行數學運算,而必須調用其相對應的方法。對象
方法中的參數也必須是BigDecimal的對象。構造器是類的特殊方法,專門用來建立對象,特別是帶有參數的對象。blog
import java.math.BigDecimal; public class T { public static void main(String[] args) { String a = "9999.9999"; int b = 9999; double c = 9999.9999; char d = 99; System.out.println("==================="); // 不一樣類型轉爲BigDecimal BigDecimal ma = new BigDecimal(a); BigDecimal mb = new BigDecimal(b); BigDecimal mc = new BigDecimal(c); BigDecimal md = new BigDecimal(d); System.out.println("ma:"+ma.toString()); System.out.println("mb:"+mb.toString()); System.out.println("mc:"+mc.toString()); System.out.println("md:"+md.toString()); System.out.println("==================="); // 加 BigDecimal add = ma.add(mb); System.out.println("加法:"+add); // 減 BigDecimal sub = ma.subtract(mb); System.out.println("減法:"+sub); // 乘 BigDecimal mul = mb.multiply(md); System.out.println("乘法:"+mul); // 除 BigDecimal div = mb.divide(md); System.out.println("除法:"+div); System.out.println("==================="); mc = mc.setScale(2, BigDecimal.ROUND_HALF_UP); System.out.println("四捨五入:"+mc); System.out.println("==================="); mc = mc.negate(); System.out.println("負數:"+mc); System.out.println("==================="); } }
BigDecimal和String的相互轉換:ip
/*由數字字符串構造BigDecimal的方法 *設置BigDecimal的小數位數的方法 */ import java.math.BigDecimal; //數字字符串 String StrBd="1048576.1024"; //構造以字符串內容爲值的BigDecimal類型的變量bd BigDecimal bd=new BigDecimal(StrBd); //設置小數位數,第一個變量是小數位數,第二個變量是取捨方法(四捨五入) bd=bd.setScale(2, BigDecimal.ROUND_HALF_UP); //轉化爲字符串輸出 String OutString=bd.toString();