前言
眾所周知Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。雙精確度浮點型變數double可以處理16位有效數。在實際應用中,需要對更大或者更小的數進行運算和處理。float和double只能用來做科學計算或者是工程計算,在商業計算中要用java.math.BigDecimal
。
BigDecimal所建立的是對象,我們不能使用傳統的+、-、*、/等算術運算子直接對其對象進行數學運算,而必須調用其相對應的方法。
方法中的參數也必須是BigDecimal的對象。構造器是類的特殊方法,專門用來建立對象,特別是帶有參數的對象。
範例程式碼如下
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("==================="); }}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的協助,如果有疑問大家可以留言交流。