Rumah > Java > javaTutorial > Mengapa Menukar Terapung kepada Ganda Nampaknya Meningkatkan Ketepatan?

Mengapa Menukar Terapung kepada Ganda Nampaknya Meningkatkan Ketepatan?

Susan Sarandon
Lepaskan: 2024-11-03 06:03:02
asal
447 orang telah melayarinya

Why Does Converting a Float to a Double Seem to Increase Precision?

Memelihara Ketepatan Berangka: Menukar Terapung kepada Berganda

Apabila bekerja dengan jenis data primitif, memastikan ketepatan adalah penting. Menukar apungan kepada dua kali boleh menyebabkan ralat pembundaran yang tidak diingini. Menghantar apungan kepada dua kali ganda secara langsung mungkin menghasilkan ketepatan tambahan yang tidak dijangka, seperti yang ditunjukkan dalam contoh:

float temp = 14009.35F;
System.out.println(Float.toString(temp)); // Prints 14009.35
System.out.println(Double.toString((double) temp)); // Prints 14009.349609375
Salin selepas log masuk

Ketepatan "tambahan" yang jelas ini sebenarnya tidak diperoleh semasa penukaran. Sebaliknya, apungan tidak mewakili nombor yang dimaksudkan dengan tepat. Double, sebaliknya, mencerminkan nilai apungan asal dengan tepat. Apabila ditukar kepada rentetan, double mendedahkan data "tersembunyi" yang terdapat dalam apungan.

Pertimbangkan contoh ini:

float f = 0.1F;
double d = f;
Salin selepas log masuk

Nilai f mungkin tepat 0.100000234523. d akan memiliki nilai yang sama, tetapi apabila ditukar kepada rentetan, ia akan muncul dengan ketepatan yang lebih tinggi, memaparkan digit "tambahan" yang telah wujud.

Menukar kepada rentetan dan belakang menghasilkan nilai berganda lebih dekat kepada perwakilan rentetan daripada apungan asal. Walau bagaimanapun, ini hanya berfaedah jika nilai rentetan benar-benar mewakili nombor yang dimaksudkan.

Perlu mempertimbangkan sama ada BigDecimal akan menjadi jenis data yang lebih sesuai untuk senario ini. BigDecimal direka khusus untuk nilai perpuluhan yang tepat, memastikan anda bekerja dengan perwakilan tepat yang anda perlukan.

Atas ialah kandungan terperinci Mengapa Menukar Terapung kepada Ganda Nampaknya Meningkatkan Ketepatan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan