在Java中進行取整,尤其是四捨五入取整還有點麻煩。
下面是我根據網上的一些解答整理的三種取整運算(包括截尾取整,四捨五入,湊整),類似於面向過程語言(如C和Basic)中的取整函數(不過在Java中它叫類的方法,“類名.方法名(參數)”的運算都是類的靜態方法)。
其中,註釋掉的那段是在網上查到的有的朋友認爲正確的四捨五入的取整方法,但是經過我的實驗卻是不正確的四捨五入的取整方法。
TestGetInt.java 源代碼
import java.math.BigDecimal;
import java.text.DecimalFormat;
public class TestGetInt{
public static void main(String[] args){
double i=2, j=2.1, k=2.5, m=2.9;
System.out.println(”舍掉小數取整:Math.floor(2)=” + (int)Math.floor(i));
System.out.println(”舍掉小數取整:Math.floor(2.1)=” + (int)Math.floor(j));
System.out.println(”舍掉小數取整:Math.floor(2.5)=” + (int)Math.floor(k));
System.out.println(”舍掉小數取整:Math.floor(2.9)=” + (int)Math.floor(m));
/* 這段被註釋的代碼不能正確的實現四捨五入取整
System.out.println(”四捨五入取整:Math.rint(2)=” + (int)Math.rint(i));
System.out.println(”四捨五入取整:Math.rint(2.1)=” + (int)Math.rint(j));
System.out.println(”四捨五入取整:Math.rint(2.5)=” + (int)Math.rint(k));
System.out.println(”四捨五入取整:Math.rint(2.9)=” + (int)Math.rint(m));
System.out.println(”四捨五入取整:(2)=” + new DecimalFormat(”0″).format(i));
System.out.println(”四捨五入取整:(2.1)=” + new DecimalFormat(”0″).format(i));
System.out.println(”四捨五入取整:(2.5)=” + new DecimalFormat(”0″).format(i));
System.out.println(”四捨五入取整:(2.9)=” + new DecimalFormat(”0″).format(i));
*/
System.out.println(”四捨五入取整:(2)=” + new BigDecimal(”2″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(2.1)=” + new BigDecimal(”2.1″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(2.5)=” + new BigDecimal(”2.5″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(2.9)=” + new BigDecimal(”2.9″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”湊整:Math.ceil(2)=” + (int)Math.ceil(i));
System.out.println(”湊整:Math.ceil(2.1)=” + (int)Math.ceil(j));
System.out.println(”湊整:Math.ceil(2.5)=” + (int)Math.ceil(k));
System.out.println(”湊整:Math.ceil(2.9)=” + (int)Math.ceil(m));
System.out.println(”舍掉小數取整:Math.floor(-2)=” + (int)Math.floor(-i));
System.out.println(”舍掉小數取整:Math.floor(-2.1)=” + (int)Math.floor(-j));
System.out.println(”舍掉小數取整:Math.floor(-2.5)=” + (int)Math.floor(-k));
System.out.println(”舍掉小數取整:Math.floor(-2.9)=” + (int)Math.floor(-m));
System.out.println(”四捨五入取整:(-2)=” + new BigDecimal(”-2″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(-2.1)=” + new BigDecimal(”-2.1″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(-2.5)=” + new BigDecimal(”-2.5″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”四捨五入取整:(-2.9)=” + new BigDecimal(”-2.9″).setScale(0, BigDecimal.ROUND_HALF_UP));
System.out.println(”湊整:Math.ceil(-2)=” + (int)Math.ceil(-i));
System.out.println(”湊整:Math.ceil(-2.1)=” + (int)Math.ceil(-j));
System.out.println(”湊整:Math.ceil(-2.5)=” + (int)Math.ceil(-k));
System.out.println(”湊整:Math.ceil(-2.9)=” + (int)Math.ceil(-m));
}
}
以上代碼用的方法我也沒有經過非常系統的學習和驗證,如果哪位朋友發現問題請一定幫忙指正一下。謝謝。
轉自:http://www.learndiary.com/2006/12/java%E8%AF%AD%E8%A8%80%E4%B8%AD%E7%9A%84%E5%8F%96%E6%95%B4%E8%BF%90%E7%AE%97%E5%8C%85%E6%8B%AC%E6%88%AA%E5%B0%BE%E5%8F%96%E6%95%B4%E5%9B%9B%E8%88%8D%E4%BA%94%E5%85%A5%E5%87%91%E6%95%B4%EF%BF%BD/