文档章节

金额,数值精确推荐BigDecimal,请勿使用double,float

尾生
 尾生
发布于 2016/08/10 15:12
字数 351
阅读 9
收藏 1

package com.text.java;

import java.math.BigDecimal;

/**
 * <p class="detail">
 * 功能:支付数字计算误差
 * </p>
 * @ClassName: PayDouble
 * @version V1.0  
 * @date 2016-8-10
 * @author wuxw
 */
public class PayDouble {
    
    public static void main1(String[] args) {  
        float f = 0.1f;  
        float sum = 0;  
        for( int i=0; i<1000000; i++)  
        {  
            sum += f;  
        }  
        System.out.println(sum);  
        // 输出:100958.34 而不是1000000
    }  
    
    //输出
    /**
     * <p class="detail">
     * 功能:0.29  
            28
     * </p>
     * @author wuxw
     * @param args
     * @throws
     */
    public static void main2(String[] args) {  
        double d = 29.0 * 0.01;  
        System.out.println(d);  
        System.out.println((int) (d * 100));  
    }
    
    
    public static void main(String[] args) {
         BigDecimal b1 = new BigDecimal(Double.toString(0.01));   
         BigDecimal total = new BigDecimal(Double.toString(0));   
         for( int i=0; i<1000000; i++)  
         {  
             total=total.add(b1);  
         }  
         System.out.println("BigDecimal total="+total);
         // 输出: 10000.00
    }
}

  1. BigDecimal(int)                 创建一个具有参数所指定整数值的对象。  
  2. BigDecimal(double)        创建一个具有参数所指定双精度值的对象。  
  3. BigDecimal(long)             创建一个具有参数所指定长整数值的对象。  
  4. BigDecimal(String)          创建一个具有参数所指定以字符串表示的数值的对象。

BigDecimal 的运算方式 不支持 + - * / 这类的运算 它有自己的运算方法:

  1. BigDecimal add(BigDecimal augend) 加法运算  
  2.     BigDecimal subtract(BigDecimal subtrahend) 减法运算  
  3.     BigDecimal multiply(BigDecimal multiplicand) 乘法运算  
  4.     BigDecimal divide(BigDecimal divisor) 除法运算  

© 著作权归作者所有

共有 人打赏支持
尾生
粉丝 16
博文 143
码字总数 59790
作品 0
杭州
程序员
私信 提问
金融系统中正确的金额计算及存储方式

image 昨天微信群里在讨论金额计算及存储的话题,今天特来结贴一下。 经典的精度丢失问题 Java中的类型float、double用来做计算会有精度丢失问题,下面来看下面的示例。 上面的程序输出结果是...

架构之路
2017/12/01
0
0
如果要求精确的答案,请避免使用float和double

float和double类型的主要设计目的是为了科学计算和工程计算。它们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果...

目翟
2013/11/19
0
3
计算金额 财务计算 精确运算 BigDecimal用法详解

一、简介 Java在java.math包中提供的API类BigDecimal,用来对超过16位有效 位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算...

jerry__sun
2016/07/07
581
1
java.math.BigDecimal保留两位小数,保留小数,精确位数

java保留两位小数问题: 方式一(四舍五入形式保留两位小数,注意模式ROUNDHALFUP): 四舍五入 double f = 111231.5585; BigDecimal b = new BigDecimal(f); double f1 = b.setScale(2, BigD...

vshcxl
2016/10/27
2.2K
0
如果需要精确的答案,请避免使用float和double

float和double类型主要是为了科学计算和工程计算而设计的。它们执行二进制浮点运算,这是为了在广泛的数值范围上提供较为精确的快速近似计算而精心设计的。它们并没有提供完全精确的结果。 ...

ksfzhaohui
2012/12/13
0
1

没有更多内容

加载失败,请刷新页面

加载更多

Android :报错Your project path contains non-ASCII characters.

报错内容如下 Your project path contains non-ASCII characters. This will most likely cause the build to fail on Windows. Please move your project to a different directory. See ht......

lanyu96
12分钟前
2
0
[LintCode] Number of Islands(岛屿个数)

描述 给一个01矩阵,求不同的岛屿的个数。 0代表海,1代表岛,如果两个1相邻,那么这两个1属于同一个岛。我们只考虑上下左右为相邻。 样例 在矩阵: [ [1, 1, 0, 0, 0], [0, 1, 0, 0, ...

honeymose
12分钟前
0
0
Nginx平滑添加模块

Nginx已经编译安装并运行了一段时间, 然后某一天, 发现需要用到某个模块但当初没有编译, 这个时候怎么办呢? 卸载重新安装肯定可以的, 如果Nginx版本没有变更的话, 则有一个相对平滑的方法来添...

老菜鸟0217
17分钟前
2
0
spark安装测试

spark安装测试 由于本地已经安装好hadoop相关组件,所以本文是在yarn的基础上对spark进行安装及测试 确保hdfs及yarn成功启动,hadoop版本为2.7.3 安装scala,由于本人安装的spark是2.4.0,对应...

-九天-
31分钟前
3
0
周末看完了《电能计量自动化技术》

整体质量还行,下面分别将心得记录如下: 第一章:发展历程可以看看,现在算是智能电网阶段 2:讲主站系统。以文件进行各模块的交互很值得思考,尤其是批量数据,多团队合作的情况下。另外线...

max佩恩
51分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部