Di Java, terdapat banyak kelas yang perlu diproses, seperti kelas Integer, tetapi kelas Integer juga mempunyai had atas. Nilai maksimumnya ialah 2^31-1.
Jika kita mahu mewakili nombor yang lebih besar pada masa ini, ia tidak boleh diwakili oleh Integer, jadi Java menyediakan kelas BigInteger.
Nombor yang disokong oleh kelas BigInteger boleh dikatakan tidak terhingga dan ia menyokong integer ketepatan sewenang-wenangnya, yang bermaksud bahawa ia boleh mewakili sebarang nilai dengan tepat tanpa kehilangan.
Saya juga ingin menekankan di sini bahawa kerana jenis nombor masuk adalah jenis aksara, anda tidak boleh menggunakan + - * semasa melakukan operasi /
bersesuaian dengan kaedah menggunakannya:
tambah(), tolak(), darab(), bahagi()
Terdapat juga beberapa kaedah biasa:
sama dengan kaedah . Bandingkan
Demonstrasi kod:
import java.math.BigInteger; public class Demo01 { public static void main(String[] args) { BigInteger bigInteger1 = new BigInteger("2222222222222222222222222222222"); BigInteger bigInteger2 = new BigInteger("1111111111111111111111111111111"); System.out.println("bigInteger1大数为:" + bigInteger1); System.out.println("bigInteger2大数为:" + bigInteger2); System.out.println("两个大数相加:" + bigInteger1.add(bigInteger2));//加 System.out.println("两个大数相减:" + bigInteger1.subtract(bigInteger2));//减 System.out.println("两个大数相乘:" + bigInteger1.multiply(bigInteger2));//乘 System.out.println("两个大数相除:" + bigInteger1.divide(bigInteger2));//除 System.out.println("两个大数相比:" + bigInteger1.equals(bigInteger2));//equals进行比较 } }
Apabila melakukan pembahagian, jika terdapat tempat perpuluhan, tempat perpuluhan dipintas di sini.
Sudah tentu, terdapat bukan sahaja jenis integer, tetapi juga jenis titik terapung.
Sudah tentu, ketepatan jenis titik terapung boleh sebesar mungkin.
import java.math.BigDecimal; public class Demo02 { public static void main(String[] args) { BigDecimal bigDecimal1 = new BigDecimal("12232423432432.53241234324"); BigDecimal bigDecimal2 = new BigDecimal("2.0"); System.out.println("bigDecimal1值: " + bigDecimal1); System.out.println("bigDecimal2值: " + bigDecimal2); System.out.println("加:" + bigDecimal1.add(bigDecimal2)); System.out.println("减:" + bigDecimal1.subtract(bigDecimal2)); System.out.println("乘:" + bigDecimal1.multiply(bigDecimal2)); System.out.println("除:" + bigDecimal1.divide(bigDecimal2)); } }
Dalam kaedah BigDecimal, ia juga boleh menyelesaikan masalah ketepatan dalam bahasa Java dengan lebih baik (seperti masalah hasil 0.1x3 == 0.3 adalah palsu)
Tetapi ada juga perkara yang perlu diberi perhatian apabila menggunakan BigDecimal (apabila ia menghadapi masalah yang tidak boleh dibahagikan, ia akan Pilih yang melaporkan ralat )
Jadi apabila melakukan pembahagian, berikan sahaja digit pemotongan.
Mari kita lihat kaedah dahulu:
pembahagi BigDecimal awam(Pembahagi Perpuluhan Besar, skala int, Mod pembulatan int)
pembahagi - pembahagi.
skala - berapa tempat perpuluhan yang perlu disimpan
Mod pembulatan - pilih mod pembundaran
supaya kita boleh menulisnya seperti ini:
Pemilihan mod pembulatan:
模式 | 意思 |
---|---|
ROUND_CEILING | 向正无穷取数 |
ROUND_DOWN | 向0取数 |
ROUND_FLOOR | 向负无穷取数 |
ROUND_HALF_DOWN | 四舍五入遇到 .5向下取数 |
ROUND_HALF_UP | 四舍五入遇到 .5向上取数 |
ROUND_HALF_EVEN | 四舍五入遇到5看前面的数,大于5向上,小于5向下,等于5再向前看。 |
Atas ialah kandungan terperinci Analisis contoh kelas BigInteger dan BigDecimal bilangan besar Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!