大家好,又见面了,我是你们的朋友全栈君。
引用处:
https://blog.csdn.net/u014704879/article/details/41479399/
https://blog.csdn.net/shruber/article/details/78413706
https://www.cnblogs.com/Dhouse/p/7776780.html
方式一:BigDecimal
double tpD = 6.15365;
BigDecimal bigD = new BigDecimal(tpD);
double tpD2 = bigD .setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
结果:6.15
解释说明:
(new BigDecimal()).setScale()方法用于格式化小数点,有多种小数保留模式,如下:
BigDecimal bigD = new BigDecimal("3.14159");
bigD.setScale(1)表示保留一位小数,默认用四舍五入方式
bigD.setScale(1,BigDecimal.ROUND_DOWN)直接删除多余的小数位,如2.35会变成2.3
bigD.setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4
bigD.setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35变成2.4
bigD.setScale(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍
对应的参数定义如下:
ROUND_CEILING
Rounding mode to round towards positive infinity.
向正无穷方向舍入
ROUND_DOWN
Rounding mode to round towards zero.
向零方向舍入
ROUND_FLOOR
Rounding mode to round towards negative infinity.
向负无穷方向舍入
ROUND_HALF_DOWN
Rounding mode to round towards "nearest neighbor" unless both neighbors are equidistant, in which case round down.
向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5
ROUND_HALF_EVEN
Rounding mode to round towards the "nearest neighbor" unless both neighbors are equidistant, in which case, round towards the even neighbor.
向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP ,如果是偶数,使用ROUND_HALF_DOWN
ROUND_HALF_UP
Rounding mode to round towards "nearest neighbor" unless both neighbors are equidistant, in which case round up.
向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6
ROUND_UNNECESSARY
Rounding mode to assert that the requested operation has an exact result, hence no rounding is necessary.
计算结果是精确的,不需要舍入模式
ROUND_UP
Rounding mode to round away from zero.
向远离0的方向舍入
PS:
1,对于BigDecimal的初始化赋值的方式有一下几种,但是推荐用字符串初始化的方式
1. BigDecimal num1 = new BigDecimal(6.285967);//这种写法不允许,会造成精度损失
2. BigDecimal num2 = new BigDecimal(2);//这种写法是可以的
3. BigDecimal num3 = new BigDecimal("6.285967");//一般都会这样写最好
方式二:Math.round()
Math.round(6.2634675 * 100) * 0.01d;
结果:6.26
解释说明:
Math.round(x) 返回对参数x四舍五入后所得的整数近似值,通过如下例子做说明
1、小数点后第一位=5
正数:Math.round(11.5)=12
负数:Math.round(-11.5)=-11
2、小数点后第一位<5
正数:Math.round(11.46)=11
负数:Math.round(-11.46)=-11
3、小数点后第一位>5
正数:Math.round(11.68)=12
负数:Math.round(-11.68)=-12
根据上面例子的运行结果,我们还可以按照如下方式总结更加容易记忆:
1、参数的小数点后第一位<5,运算结果为参数整数部分。
2、参数的小数点后第一位>5,运算结果为参数整数部分绝对值+1,符号(即正负)不变。
3、参数的小数点后第一位=5,正数运算结果为整数部分+1,负数运算结果为整数部分。
总结:大于五全部加,等于五正数加,小于五全不加。
Math.round
语法:
Math.round(x);
参数:
x 为一数值。
解释:
方法。返回对参数x四舍五入后所得的整数近似值。
round
public static long round(double a)
返回最接近参数的 long。结果将舍入为整数:加上 1/2,对结果调用 floor 并将所得结果强制转换为long 类型。换句话说,结果等于以下表达式的值:
(long)Math.floor(a + 0.5d)
特殊情况如下:
如果参数为 NaN,那么结果为 0。
如果结果为负无穷大或任何小于等于 Long.MIN_VALUE 的值,那么结果等于Long.MIN_VALUE 的值。
如果参数为正无穷大或任何大于等于 Long.MAX_VALUE 的值,那么结果等于Long.MAX_VALUE 的值。
参数:
a - 舍入为 long 的浮点值。
返回:
舍入为最接近的 long 值的参数值。
round
public static int round(float a)
返回最接近参数的 int。结果将舍入为整数:加上 1/2,对结果调用 floor 并将所得结果强制转换为int 类型。换句话说,结果等于以下表达式的值:
(int)Math.floor(a + 0.5f)
特殊情况如下:
如果参数为 NaN,那么结果为 0。
如果结果为负无穷大或任何小于等于 Integer.MIN_VALUE 的值,那么结果等于Integer.MIN_VALUE 的值。
如果参数为正无穷大或任何大于等于 Integer.MAX_VALUE 的值,那么结果等于Integer.MAX_VALUE 的值。
参数:
a - 要舍入为整数的浮点值。
返回:
舍入为最接近的 int 值的参数值。
---------------------
4.3<4.4<4.5 so
math.round(4.3)=4
math.round(4.4)=4
math.round(4.5)=5
-4.6<-4.5 <-4.4 so
math.round(-4.6)=-5
math.round(-4.5)=-4
math.round(-4.4)=-4
-4.51 |-4.50 -4.49
4.49 | 4.50 4.51
因为是负数,所以临界点都是在5的左侧,文字上的“四舍五入”,让人容易糊涂
四舍五入都是往右边计算:
-----(-5)-----(-4.6)(-4.5)(-4.4)-----(-4)----------(0)----------(4)-----(4.4)(4.5)(4.6)-----(5)-----
-----(-5)<---(-4.6)(-4.5)---------->(-4)----------(0)----------(4)<----------(4.5)(4.6)--->(5)-----
-------------------------------(-4.4)--->(-4)---------(0)-----------(4)<---(4.4)----------------------------
注意这些数字的位置关系,正数和负数并不是对称关系,Math.round()的运算时都是由左向右运算,所以:
4.5四舍五入应该是取大值为5,-4.5也一样,取大值为-4,因为-4>-4.5>-5
PS:
1,这里说下Math.floor(),其返回值表示小于或等于指定数字的最大整数的数字,如下:
Math.floor( 45.95);
// 45
Math.floor( 45.05);
// 45
Math.floor( 4 );
// 4
Math.floor(-45.05);
// -46
Math.floor(-45.95);
// -46
方式三:DecimalFormat
new java.text.DecimalFormat("#.00").format(6.1435829);
结果:6.14
解释说明:
DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。它可以支持不同类型的数,包括整数 (123)、定点数 (123.4)、科学记数法表示的数 (1.23E4)、百分数 (12%) 和金额 ($123)这些内容的本地化与区域化,如下例子说明:
DecimalFormat df1 = new DecimalFormat("###,###.0000");//使用系统默认的格式
System.out.println(df1.format(111111123456.12));
结果:111,111,123,456.1200
Locale.setDefault(Locale.US);//指定区域格式 ,这里使用美国的格式
DecimalFormat df2= new DecimalFormat();
System.out.println(df2.format(111111123456.1200));
结果:111,111,123,456.12
Locale.setDefault(Locale.FRANCE);//指定区域格式,法国
DecimalFormat df2= new DecimalFormat("###,###.0000");//使用区域格式前提下自定义改造
System.out.println(df2.format(111111123456.12));
结果:111 111 123 456,1200
//----------------------------also use applypattern------------------------------//
DecimalFormat df3= new DecimalFormat();
myformat3.applyPattern("##,###.000");
System.out.println(df3.format(11112345.12363)); //这里有四舍五入
结果:11,112,345.124
//-----------------控制指数输出-------------------------------------------------//
DecimalFormat df4= new DecimalFormat();
myformat4.applyPattern("0.000E0000");
System.out.println(df4.format(10000));
System.out.println(df4.format(12345678.345)); //这里有四舍五入
结果: 1.000E0004 1.235E0007
//------------------百分数的输出-------------------------------------------//
DecimalFormat df5= null;
try{
df5= (DecimalFormat)NumberFormat.getPercentInstance();
}catch(ClassCastException e){
throw e;
}
df5.applyPattern("00.0000%");
System.out.println(df5.format(0.34567));
System.out.println(df5.format(1.34567));
结果:34.5670% 134.5670%
DecimalFormat 包含一组符号,对于各符号的含义解释如下:
0 一个数字
# 一个数字,不包括 0
. 小数的分隔符的占位符
, 分组分隔符的占位符
; 分隔格式。
– 缺省负数前缀。
% 乘以 100 和作为百分比显示
? 乘以 1000 和作为千进制货币符显示;用货币符号代替;如果双写,用国际货币符号代替。如果出现在一个模式中,用货币十进制分隔符代 替十进制分隔符。
X 前缀或后缀中使用的任何其它字符,用来引用前缀或后缀中的特殊字符。
PS:
1,DecimalFormat是NumberFormat的一个子类,其实例被指定为特定的地区。因此,你可以使用NumberFormat.getInstance 指定一个地区,然后将结构强制转换为一个DecimalFormat对象。文档中提到这个技术可以在大多情况下适用,但是你需要用try/catch 块包围强制转换以防转换不能正常工作 (大概在非常不明显得情况下使用一个奇异的地区)。
方式四:String.format()
/**
* %.2f %. 表示 小数点前任意位数 2 表示两位小数 格式后的结果为f 表示浮点型
/
double tpD = 6.1435628;
String result = String.format("%.2f", tpD );
结果:6.14
解释说明:
详细看:JAVA字符串格式化-String.format()的使用
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/143621.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...