Masalah Pembahagian Integer: Memahami Ralat dalam Operasi Aritmetik Java
Di Java, pembahagian yang melibatkan nilai integer boleh mengakibatkan ralat yang tidak dijangka jika hasil yang diinginkan melibatkan nombor perpuluhan. Untuk memahami isu ini, adalah penting untuk memahami konsep pembahagian integer.
Pembahagian integer berbeza daripada pembahagian titik terapung kerana ia membuang bahagian pecahan hasil. Tingkah laku ini boleh menyebabkan ketidaktepatan apabila membahagikan dua integer, seperti dalam contoh yang disediakan:
float res = quantity / standard;
Pembahagian antara kuantiti dan piawai akan menghasilkan keputusan integer, membuang sebarang nilai perpuluhan. Walaupun dengan pengiraan yang kelihatan mudah, seperti 6800 / 500, anda akan mendapat 13.0 dan bukannya 13.6 yang dijangkakan.
Untuk membetulkannya, anda boleh memaksa pengangka untuk dianggap sebagai apungan menggunakan sintaks berikut :
float res = (float) quantity / standard;
Ini memaksa penyebut untuk dilemparkan sebagai pelampung juga, melaksanakan pembahagian titik terapung dengan berkesan. Sebagai alternatif, anda boleh menambah huruf 'f' pada penyebut:
float f = 6800f / 500;
Dengan berbuat demikian, anda secara eksplisit mengisytiharkan penyebut sebagai apungan, memastikan hasil pembahagian yang betul.
Atas ialah kandungan terperinci Mengapa Pembahagian Integer di Jawa Membawa kepada Keputusan Yang Tidak Dijangka?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!