一、Math.round()方法實現四捨五入
Java Math庫提供了一個直接的方法Math.round(),可以實現基本數據類型(float, double, long, int)、BigDecimal、BigInteger的四捨五入處理。其中,float類型和double類型的四捨五入處理是基於舍入到最近一位的規則。
public static long round(double a) public static int round(float a)
返回一個long或int類型的值,表示參數a最接近的整數。如果a等於兩個整數的中間值,則返回偶數(即四捨五入)。例如:
long result1 = Math.round(43.5);//44 long result2 = Math.round(43.499);//43 int result3 = Math.round(43.49F);//43 int result4 = Math.round(43.51F);//44
二、實現自定義級別的四捨五入
有時候,我們需要實現不同精度級別的四捨五入操作。這時候可以使用如下方法:
public static double round(double value, int places) { if (places < 0) throw new IllegalArgumentException(); BigDecimal bd = new BigDecimal(value); bd = bd.setScale(places, RoundingMode.HALF_UP); return bd.doubleValue(); }
其中,value為被處理的參數,places為要保留的小數點後位數。例如:
double result1 = round(1.234, 2);//1.23 double result2 = round(1.236, 2);//1.24 double result3 = round(1.234, 3);//1.234 double result4 = round(1.236, 3);//1.236
三、自己手寫四捨五入邏輯實現
如果需要實現特定的四捨五入邏輯,可以自己編寫代碼實現。下面的代碼實現了根據小數點後一位是否大於等於5來進行舍入處理的邏輯。
public static double myRound(double num) { double temp = num * 10; long result = Math.round(temp); return result / 10.0; }
例如:
double result1 = myRound(1.234);//1.2 double result2 = myRound(1.237);//1.2 double result3 = myRound(1.236);//1.2 double result4 = myRound(1.239);//1.2
四、結語
Java Math庫提供了基本數據類型、BigDecimal、BigInteger的四捨五入實現方法,並且可以方便地實現自定義精度級別的四捨五入邏輯。如果需要實現特定的四捨五入邏輯,可以根據要求自己手寫代碼實現。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/184386.html