前言
眾所周知Java在java.math包中提供的API類BigDecimal,用來對超過16位有效位的數進行精確的運算。雙精度浮點型變量double可以處理16位有效數。在實際應用中,需要對更大或者更小的數進行運算和處理。float和double只能用來做科學計算或者是工程計算,在商業計算中要用java.math.BigDecimal
。
BigDecimal所創建的是對象,我們不能使用傳統的+、-、*、/等算術運算符直接對其對象進行數學運算,而必須調用其相對應的方法。
方法中的參數也必須是BigDecimal的對象。構造器是類的特殊方法,專門用來創建對象,特別是帶有參數的對象。
示例代碼如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
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( "===================" ); } } |
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。