java 保留两位小数的几种方法_java

1.代码:

import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.text.NumberFormat;

public class format {
 double f = 111231.5585;
 public void m1() {
  BigDecimal bg = new BigDecimal(f);
  double f1 = bg.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
  System.out.println(f1);
 }
 /**
  * DecimalFormat转换最简便
  */
 public void m2() {
  DecimalFormat df = new DecimalFormat("#.00");
  System.out.println(df.format(f));
 }
 /**
  * String.format打印最简便
  */
 public void m3() {
  System.out.println(String.format("%.2f", f));
 }
 public void m4() {
  NumberFormat nf = NumberFormat.getNumberInstance();
  nf.setMaximumFractionDigits(2);
  System.out.println(nf.format(f));
 }
 public static void main(String[] args) {
  format f = new format();
  f.m1();
  f.m2();
  f.m3();
  f.m4();
 }
}

2.输出结果:

111231.56
111231.56
111231.56
111,231.56

这里我们提供了一个工具类,定义浮点数的加、减、乘、除和四舍五入等运算方法。以供参考。

源文件MathExtend.java:


import java.math.BigDecimal;

public class MathExtend

{

 //默认除法运算精度

 private static final int DEFAULT_DIV_SCALE = 10;

 /**

 * 提供精确的加法运算。

 * @param v1

 * @param v2

 * @return 两个参数的和

 */

 public static double add(double v1, double v2)

 {

   BigDecimal b1 = new BigDecimal(Double.toString(v1));

   BigDecimal b2 = new BigDecimal(Double.toString(v2));

   return b1.add(b2).doubleValue();

 }

 /**

  * 提供精确的加法运算

  * @param v1 

  * @param v2

  * @return 两个参数数学加和,以字符串格式返回

  */

 public static String add(String v1, String v2)

 {

   BigDecimal b1 = new BigDecimal(v1);

   BigDecimal b2 = new BigDecimal(v2);

   return b1.add(b2).toString();

 }

 /**

 * 提供精确的减法运算。

 * @param v1

 * @param v2

 * @return 两个参数的差

 */

 public static double subtract(double v1, double v2)

 {

   BigDecimal b1 = new BigDecimal(Double.toString(v1));

   BigDecimal b2 = new BigDecimal(Double.toString(v2));

   return b1.subtract(b2).doubleValue();

 }

 /**

  * 提供精确的减法运算

  * @param v1

  * @param v2

  * @return 两个参数数学差,以字符串格式返回

  */

 public static String subtract(String v1, String v2)

 {

   BigDecimal b1 = new BigDecimal(v1);

   BigDecimal b2 = new BigDecimal(v2);

   return b1.subtract(b2).toString();

 }

 /**

 * 提供精确的乘法运算。

 * @param v1

 * @param v2

 * @return 两个参数的积

 */

 public static double multiply(double v1, double v2)

 {

   BigDecimal b1 = new BigDecimal(Double.toString(v1));

   BigDecimal b2 = new BigDecimal(Double.toString(v2));

   return b1.multiply(b2).doubleValue();

 }

 /**

  * 提供精确的乘法运算

  * @param v1

  * @param v2

  * @return 两个参数的数学积,以字符串格式返回

  */

 public static String multiply(String v1, String v2)

 {

   BigDecimal b1 = new BigDecimal(v1);

   BigDecimal b2 = new BigDecimal(v2);

   return b1.multiply(b2).toString();

 }

 /**

 * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到

 * 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN

 * @param v1

 * @param v2

 * @return 两个参数的商

 */

 public static double divide(double v1, double v2)

 {

   return divide(v1, v2, DEFAULT_DIV_SCALE);

 }

 /**

  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指

  * 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN

  * @param v1

  * @param v2

  * @param scale 表示需要精确到小数点以后几位。

  * @return 两个参数的商

  */

 public static double divide(double v1,double v2, int scale)

 {

   return divide(v1, v2, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**

  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指

  * 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式

  * @param v1

  * @param v2

  * @param scale 表示需要精确到小数点以后几位

  * @param round_mode 表示用户指定的舍入模式

  * @return 两个参数的商

  */

 public static double divide(double v1,double v2,int scale, int round_mode){

     if(scale < 0)

     {

       throw new IllegalArgumentException("The scale must be a positive integer or zero");

     }

     BigDecimal b1 = new BigDecimal(Double.toString(v1));

     BigDecimal b2 = new BigDecimal(Double.toString(v2));

     return b1.divide(b2, scale, round_mode).doubleValue();

 }

 /**

  * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到

  * 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN

  * @param v1

  * @param v2

  * @return 两个参数的商,以字符串格式返回

  */

 public static String divide(String v1, String v2)

 {

   return divide(v1, v2, DEFAULT_DIV_SCALE);

 }

 /**

  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指

  * 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN

  * @param v1

  * @param v2

  * @param scale 表示需要精确到小数点以后几位

  * @return 两个参数的商,以字符串格式返回

  */

 public static String divide(String v1, String v2, int scale)

 {

   return divide(v1, v2, DEFAULT_DIV_SCALE, BigDecimal.ROUND_HALF_EVEN);

 }

 /**

  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指

  * 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式

  * @param v1

  * @param v2

  * @param scale 表示需要精确到小数点以后几位

  * @param round_mode 表示用户指定的舍入模式

  * @return 两个参数的商,以字符串格式返回

  */

 public static String divide(String v1, String v2, int scale, int round_mode)

 {

   if(scale < 0)

   {

     throw new IllegalArgumentException("The scale must be a positive integer or zero");

   }

   BigDecimal b1 = new BigDecimal(v1);

   BigDecimal b2 = new BigDecimal(v2);

   return b1.divide(b2, scale, round_mode).toString();

 }

 /**

  * 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN

  * @param v 需要四舍五入的数字

  * @param scale 小数点后保留几位

  * @return 四舍五入后的结果

  */

 public static double round(double v,int scale)

 {

   return round(v, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**

  * 提供精确的小数位四舍五入处理

  * @param v 需要四舍五入的数字

  * @param scale 小数点后保留几位

  * @param round_mode 指定的舍入模式

  * @return 四舍五入后的结果

  */

 public static double round(double v, int scale, int round_mode)

 {

   if(scale<0)

   {

     throw new IllegalArgumentException("The scale must be a positive integer or zero");

   }

   BigDecimal b = new BigDecimal(Double.toString(v));

   return b.setScale(scale, round_mode).doubleValue();

 }

 /**

  * 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN

  * @param v 需要四舍五入的数字

  * @param scale 小数点后保留几位

  * @return 四舍五入后的结果,以字符串格式返回

  */

 public static String round(String v, int scale)

 {

  return round(v, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**

  * 提供精确的小数位四舍五入处理

  * @param v 需要四舍五入的数字

  * @param scale 小数点后保留几位

  * @param round_mode 指定的舍入模式

  * @return 四舍五入后的结果,以字符串格式返回

  */

 public static String round(String v, int scale, int round_mode)

 {

   if(scale<0)

   {

     throw new IllegalArgumentException("The scale must be a positive integer or zero");

   }

   BigDecimal b = new BigDecimal(v);

   return b.setScale(scale, round_mode).toString();

 }

}

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索java除法保留两位小数、java 保留两位小数、java小数点保留两位、java保留小数点后两位、java相除保留两位小数,以便于您获取更多的相关知识。

时间: 2024-10-06 05:42:05

java 保留两位小数的几种方法_java的相关文章

java使double保留两位小数的多方法 java保留两位小数_java

复制代码 代码如下: 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.230.00 2.00 java保留两位小数

java四舍五入float保留两位小数

例子1 float   f   =  34.237323f;  BigDecimal   b  =   new BigDecimal(f);  float   f1   =  b.setScale(2, BigDecimal.ROUND_HALF_UP).floatValue();  System.out.println(f1); 方法2: float   f   =   34.232323; BigDecimal   b   =   new   BigDecimal(f); float   f

java 保留N位小数实现程序

方式一: 四舍五入 double   f   =   111231.5585; 四舍五入 保留两位小数,可以用String的format函数, 方法如下:  代码如下 复制代码 System.out.println(String.format("%.2f", x1)); System.out.println(String.format("%.2f", x2)); DecimalFormat转换最简便    代码如下 复制代码 public void m2() {  

JS保留两位小数,多位小数的示例代码

 本篇文章主要是对JS保留两位小数,多位小数的示例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助   代码如下: <SCRIPT LANGUAGE="JavaScript"> <!-- function formatFloat(src, pos) {     return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos); }   alert(formatFloat("1212.2323&q

使用Mybatis框架,如何使查询结果float数据保留两位小数

问题描述 <resultMap type="ProductSku" id="resultProductSku"><id column="id" property="id" /><result column="sku_code" property="skuCode" /><result column="sku_price" pr

class-现有Double类型的数据,如何转换为保留两位小数的数,返回值的类型仍然是Double类型的。

问题描述 现有Double类型的数据,如何转换为保留两位小数的数,返回值的类型仍然是Double类型的. 各位大虾,现有Double类型的数据,如何转换为保留两位小数的数,返回值的类型仍然是Double类型的,而不是字符串类型. 解决方案 double a=1.2345; a=int(a*100)/100.0; 解决方案二: 在java里面没有四舍五入,c,c++才有. java a=int(a*100+0.5)/100.0; 这种很快捷 C 直接输出system.out.printf("%2.

javascript实现保留两位小数的多种方法_javascript技巧

第一种方法:javascript实现保留两位小数一位自动补零代码实例:第一种方法介绍一下如何实现对数字保留两位小数效果,如果数字的原本小数位数不到两位,那么缺少的就自动补零,这个也是为了统一的效果,先看代码实例: function returnFloat(value){ var value=Math.round(parseFloat(value)*100)/100; var xsd=value.toString().split("."); if(xsd.length==1){ valu

js实现四舍五入完全保留两位小数的方法_javascript技巧

本文实例讲述了js实现四舍五入完全保留两位小数的方法.分享给大家供大家参考,具体如下: //四舍五入保留2位小数(若第二位小数为0,则保留一位小数) function keepTwoDecimal(num) { var result = parseFloat(num); if (isNaN(result)) { alert('传递参数错误,请检查!'); return false; } result = Math.round(num * 100) / 100; return result; }

JS保留两位小数

    JS保留两位小数       对于一些小数点后有多位的浮点数,我们可能只需要保留2位,但js没有提供这样直接的函数,所以我们得自己写函数实现这个功能,代码如下: function changeTwoDecimal(x) {    var f_x = parseFloat(x);    if (isNaN(f_x))    {       alert('function:changeTwoDecimal->parameter error');       return false;