Java中double类型四舍五入的方法总结
代码:
double a = 13.245;
//方法一:
BigDecimal bd= new BigDecimal(a);
Double b = bd.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
System.out.println("方法一: "+b);
//方法二:
Double myValue = new BigDecimal(a).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
java.text.NumberFormat nf = java.text.NumberFormat.getInstance();
nf.setGroupingUsed(false);
System.out.println("方法二: "+myValue);
//方法三:
// #.00 表示两位小数 #.0000四位小数
DecimalFormat df2 =new DecimalFormat("#.00");
String str2 =df2.format(a);
System.out.println("方法三: "+str2);
//方法四:
//%.2f 中的% 表示 小数点前任意位数 2 表示两位小数 格式后的结果为f 表示浮点型
String result = String.format("%.2f", a);
System.out.println("方法四: "+result);
解析:
//保留两位时 :0.245 0.295 保留一位时: 0.45 0.95
当double a = 13.245时,输出结果为:
方法一: 13.24
方法二: 13.24
方法三: 13.24
方法四: 13.25
当double a = 13.295时,输出结果为:
方法一: 13.29
方法二: 13.29
方法三: 13.29
方法四: 13.30
当保留一位小数时,若小数点后两位是 45 或 95 时,前三个方法也会有误差.
当double a = 0.295时,输出结果为:
方法一: 0.29
方法二: 0.29
方法三: .29
方法四: 0.30
当小数点前的数只有一个 0 时,可以发现方法三错的离谱.
综上,显然,使用第四种方法进行四舍五入更加精确.
===
public static void main(String[] args) {
System.out.println("向上取整:" + (int) Math.ceil(96.1));// 97 (去掉小数凑整:不管小数是多少,都进一)
System.out.println("向下取整" + (int) Math.floor(96.8));// 96 (去掉小数凑整:不论小数是多少,都不进位)
System.out.println("四舍五入取整:" + Math.round(96.1));// 96 (这个好理解,不解释)
System.out.println("四舍五入取整:" + Math.round(96.8));// 97
}
===
mport java.text.DecimalFormat;
DecimalFormat df = new DecimalFormat("######0.00"); double d1 = 3.23456
double d2 = 0.0;
double d3 = 2.0;
df.format(d1);
df.format(d2);
df.format(d3);
3个结果分别为:
3.23
0.00
2.00
java保留两位小数问题:
方式一:
四舍五入
double f = 111231.5585;
BigDecimal b = new BigDecimal(f);
double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
保留两位小数
方式二:
java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
df.format(你要格式化的数字);
例:
new java.text.DecimalFormat("#.00").format(3.1415926)
#.00 表示两位小数 #.0000四位小数 以此类推...
方式三:
double d = 3.1415926;
String result = String .format("%.2f");
%.2f %. 表示 小数点前任意位数 2 表示两位小数 格式后的结果为f 表示浮点型
NumberFormat ddf1=NumberFormat.getNumberInstance() ;
void setMaximumFractionDigits(int digits)
digits 显示的数字位数
为格式化对象设定小数点后的显示的最多位,显示的最后位是舍入的
import java.text.* ;
import java.math.* ;
class TT
{
public static void main(String args[])
{ double x=23.5455;
NumberFormat ddf1=NumberFormat.getNumberInstance() ;ddf1.setMaximumFractionDigits(2);
String s= ddf1.format(x) ;
System.out.print(s);
}
}
import java.text.*;
DecimalFormat df=new DecimalFormat(".##");
double d=1252.2563;
String st=df.format(d);
System.out.println(st);
下面是百度
1. 功能
将程序中的double值精确到小数点后两位。可以四舍五入,也可以直接截断。
比如:输入12345.6789,输出可以是12345.68也可以是12345.67。至于是否需要四舍五入,可以通过参数来决定(RoundingMode.UP/RoundingMode.DOWN等参数)。
2. 实现代码
package com.clzhang.sample;import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.text.NumberFormat;public class DoubleTest {/*** 保留两位小数,四舍五入的一个老土的方法* @param d* @return*/public static double formatDouble1(double d) {return (double)Math.round(d*100)/100;}/*** The BigDecimal class provides operations for arithmetic, scale manipulation, rounding, comparison, hashing, and format conversion.* @param d* @return*/public static double formatDouble2(double d) {// 旧方法,已经不再推荐使用
// BigDecimal bg = new BigDecimal(d).setScale(2, BigDecimal.ROUND_HALF_UP);// 新方法,如果不需要四舍五入,可以使用RoundingMode.DOWNBigDecimal bg = new BigDecimal(d).setScale(2, RoundingMode.UP);return bg.doubleValue();}/*** NumberFormat is the abstract base class for all number formats. * This class provides the interface for formatting and parsing numbers.* @param d* @return*/public static String formatDouble3(double d) {NumberFormat nf = NumberFormat.getNumberInstance();// 保留两位小数nf.setMaximumFractionDigits(2); // 如果不需要四舍五入,可以使用RoundingMode.DOWNnf.setRoundingMode(RoundingMode.UP);return nf.format(d);}/*** 这个方法挺简单的。* DecimalFormat is a concrete subclass of NumberFormat that formats decimal numbers. * @param d* @return*/public static String formatDouble4(double d) {DecimalFormat df = new DecimalFormat("#.00");return df.format(d);}/*** 如果只是用于程序中的格式化数值然后输出,那么这个方法还是挺方便的。* 应该是这样使用:System.out.println(String.format("%.2f", d));* @param d* @return*/public static String formatDouble5(double d) {return String.format("%.2f", d);}public static void main(String[] args) {double d = 12345.67890;System.out.println(formatDouble1(d));System.out.println(formatDouble2(d));System.out.println(formatDouble3(d));System.out.println(formatDouble4(d));System.out.println(formatDouble5(d));}}
3. 输出
12345.68
12345.68
12,345.68
12345.68
12345.68
在法语环境下,除了前两种方法显示正常之外,后边三种方法会将小数点显示成逗号,如果做国际化要注意
===
package airthmatic;
public class demo10 {
public static void main(String[] args) {
double n[]={9,1.2,5,3.2,1.1};
orderNum(n);
}
/**
* double 和 int 数字排序
* @param n
*/
public static void orderNum(double []n){
for(int i=0;i<n.length-1;i++){
for(int j=0;j<n.length-1-i;j++){
double temp=0;
if(n[j]>n[j+1]){
temp=n[j+1];
n[j+1]=n[j];
n[j]=temp;
}
}
}
/**
* 这里是过滤掉整数的double类型
*/
for(int i=0;i<n.length;i++){
int temp=(int)n[i];
if(n[i]%temp==0){
System.out.println(temp);
}else{
System.out.println(n[i]);
}
}
}
}
Java中double类型四舍五入的方法总结相关推荐
- java double 转string_double转string java中double类型如何转换为String类型
double转string java中double类型如何转换为String类型 在我们做的项目中,有一个字符串的生成,我们需要double去拼接,结果发现了,拼接后的字符串,那个double值用科学 ...
- Java中double类型输出小数点后两位
Java中double类型输出小数点后两位 思路 就是在输出的时候使用字符串格式即可. double testNum=1.123456789;System.out.println(String.for ...
- java中double类型精度丢失问题及解决方法
点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 来源: https://blog.csdn.net/yacolsp ...
- Java中double类型比较大小或相等的方法
在Java中int类型数据的大小比较可以使用双等号,double类型则不能使用双等号来比较大小,如果使用的话得到的结果将永远是不相等,即使两者的精度是相同的也不可以.下面介绍两种比较double数据是 ...
- Java中double类型大小比较的五种方法
文章目录 1.使用BigDecimal 2.使用包装类Double 3.在误差范围内运行相等 4.转换成字符串 5.使用doubleToLongBits()方法 在Java中 int类型数据的大小比较 ...
- java中double类型占几个字节_java中各种数据类型占用字节数
1字节(Byte)=8bit java的基本类型 类型 所占字节 byte 1 short 2 int 4 long 8 float 4 double 8 char 2 String中字母和汉字所占字 ...
- Java中double类型精度丢失的问题_double类型数据加减操作精度丢失解决方法_BigDecimal取整
BigDecimal在用double做入参的时候,二进制无法精确地表示十进制小数,编译器读到字符串"0.0000002"和"1.0000002"之后,必须把它转 ...
- java double 运算精度问题_关于java中Double类型的运算精度问题
如果我们编译运行下面这个程序会看到什么? public class Test{ public static void main(String args[]){ System.o ...
- 如何使java中double类型不以科学计数法表示
http://vincentboy.iteye.com/blog/1647187 问题:在java中,怎样把一个double数转换为字符串时,不用科学计数法表示. 解决方法1: //对Double类型 ...
最新文章
- 北科院分子互作实战专题培训班(10月底/11月底班)(生物医药与营养健康协同创新中心)...
- 一个风格诡异的ABAP学习网站
- TOTP 介绍及基于 C# 的简单实现
- tensorflow打印模型图_从Tensorflow模型文件中解析并显示网络结构图(pb模型篇)...
- 模拟linux终端测试java,介绍一个在线的Linux,没有安装Linux或者虚拟机不喜欢用的童鞋可以简单的用这个jslinux测试各种命令...
- ftk学习记(脚本篇)
- windows环境下的YOLO3入门,及opencv344配置
- 1.数据结构 --- 绪论
- Atitit.通过null 参数 反射 动态反推方法调用
- 毛星云opencv之DrawLine函数写法
- MarkDown在线编辑器(支持公众号知乎)
- linux设置北京时区
- 计算机与3d打印导板,计算机导航系统、3D打印截骨导板与传统器械对全膝关节置换术手术时间和下肢力线恢复的影响...
- WimTool安装使用方法
- 【已解决】python 使用xlrd,xlwt 修改execl单元格的背景色
- 手机桌面计算机显示,手机如何显示在桌面?敬业签电脑手机同步云便签怎么在桌面显示便签?...
- 『迷你教程』识别人类活动的一维卷积神经网络模型,附完整代码
- 来一起造轮子:手写 Vue3 reactivity 模块
- S合金元素对不锈钢组织和性能的影响
- 535. TinyURL 的加密与解密(Medium)
热门文章
- python如何输入多行数据合并_关于Python中的合并字典,这些问题必须搞清楚!
- tiktok跨境出海?
- P-GCN:Graph Convolutional Networks for Temporal Action Localization 2019 ICCV
- 非递归中序,后序,先序遍历二叉树完整代码(用链式栈实现)
- Linux-系统性能指标
- swift - scrollview 判断左右移动, 以及上下两个view联动
- centos7 设置ssh免密码登录配置方法
- 性能测试:基础(5)
- python自定义一个可迭代类_python进阶之自定义可迭代的类
- js 清除html页面,如何清除使用JavaScript输入的HTML文件?