java 四舍五入保留小数的几种方式

java 四舍五入保留小数的几种方式引用处:https://blog.csdn.net/u014704879/article/details/41479399/https://blog.csdn.net/shruber/article/details/78413706https://www.cnblogs.com/Dhouse/p/7776780.html方式一:BigDecimaldoubletpD=6.1…

大家好,又见面了,我是你们的朋友全栈君。

引用处:
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()的使用

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143621.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 怎样防止苹果系统更新_苹果手机屏蔽系统更新描述文件链接,可屏蔽ios12更新…「建议收藏」

    https://beta.thuthuatios.com/tvos/tvOS_12_Beta_Profile.mobileconfig苹果手机屏蔽系统更新描述文件,屏蔽最新ios12版本更新!安装方法:长按复制上面链接,复制到safari浏览器打开浏览,再安装即可,会提示重启!手机重启后,去手机删除已下载的系统更新包ios12.1文件!删除更新包操作:设置-通用-储存空间与iclo…

    2022年4月11日
    108
  • 查看GCC版本_qt版本

    查看GCC版本_qt版本查看交叉编译器的GCC版本:hedy@ubuntu:~/u-boot$arm-poky-linux-gnueabi-gcc-v查看本地编译器的GCC版本:hedy@ubuntu:~/u-boot$gcc-vhedy@ubuntu:~/u-boot$whicharm-poky-linux-gnueabi-gcc/opt/fsl-imx-fb/4.1.15-2.1.0/s…

    2022年4月19日
    108
  • C语言基础知识入门(大全)「建议收藏」

    C语言基础知识入门(大全)「建议收藏」一.C语言入门C语言一经出现就以其功能丰富、表达能力强、灵活方便、应用面广等特点迅速在全世界普及和推广。C语言不但执行效率高而且可移植性好,可以用来开发应用软件、驱动、操作系统等。C语言也是其它众多高级语言的鼻祖语言,所以说学习C语言是进入编程世界的必修课!更多详细进阶教程等你领取!可以关注公众号“C和C加加”回复“ZXC”即可免费获取!二.C语言的具体结构简单来说,一个C程序就是由若干头文件和函数组成。 #include<stdio.h>就是一条预处理命..

    2022年6月7日
    25
  • keras卷积层_keras实现全卷积神经网络

    keras卷积层_keras实现全卷积神经网络分组卷积在pytorch中比较容易实现,只需要在卷积的时候设置group参数即可比如设置分组数为2conv_group=nn.Conv2d(C_in,C_out,kernel_size=3,stride=3,padding=1,groups=2)但是,tensorflow中目前还没有分组卷积,只能自己手动编写分组卷积函数。在编写程序之前大家要先理解分组卷积的形式,也就是对特征图在通道上进行划分,例如设置group=3,对输入特征图通道划分成三组,输出特征图也要划分成3组,再对三组输入输出特

    2025年6月23日
    0
  • 【转载】分布式系统理论基础 – 一致性、2PC和3PC

    【转载】分布式系统理论基础 – 一致性、2PC和3PC

    2021年11月20日
    44
  • Springboot 使用校验框架validation校验

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:双斜杠少年 blog.csdn.net/u012373815/article/details/72049796…

    2021年6月25日
    76

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号