四舍五入PK银行四舍五入

描述

  在实际开发中decimal.Round(1.23525,4)!=1.2353实际是1.2352,而decimal.Round(1.23535,4)==1.2354

说明

  四舍五入:当舍去位的数值大于等于5时,在舍去该位的同时向前位进一;当舍去位的数值小于5时,则直接舍去该位。

  银行四舍五入:当舍去位的数值小于5时,直接舍去该位;当舍去位的数值大于等于6时,在舍去该位的同时向前位进一;当舍去位的数值等于5时,如果前位数值为奇,则在舍去该位的同时向前位进一,如果前位数值为偶,则直接舍去该位。

eg:我们对1.234,1.345,1.355,1.366分别进行四舍五入和银行四舍五入

  四舍五入        银行四舍五入

    1.23          1.23

    1.35          1.34

    1.36          1.36

    1.37          1.37

解决方法

  我们既可以使用Round带三个参数的Round方法实现四舍五入,但枚举值必须使用MidpointRounding.AwayFromZero(四舍五入),而不能使用MidpointRounding.ToEven(银行四舍五入)。

测试有效效果

  decimal.Round(1.23525,4,MidpointRounding.AwayFromZero)=1.2353,而decimal.Round(1.23535,4,MidpointRounding.AwayFromZero)==1.2354

参考资料

  本文参考 “李涛的技术专栏” 博客,http://terryli.blog.51cto.com/704315/154840

时间: 2024-11-05 18:15:58

四舍五入PK银行四舍五入的相关文章

iOS 浮点数四舍五入的方法

//四舍五入 /** *  浮点型数据四舍五入 * *  @param format 保留两位小数  传入@"0.00"; *  @param floatV 字符数据 * *  @return 四舍五入保留两位后的字符串 */ +(NSString *) decimalwithFormat:(NSString *)format  floatV:(float)floatV { NSNumberFormatter *numberFormatter = [[NSNumberFormatter

跟王老师学MySQL:MySQL数据类型之小数类型

跟王老师学MySQL:MySQL数据类型之小数类型 主讲教师:王少华   QQ群号:483773664 学习内容 小数类型有哪些以及它们的取值范围 定义语法中的M和D的含义 定点型和浮点型的区别 一.简介 MySQL中使用浮点数类型和定点数类型来表示小数. 浮点数类型包括单精度浮点数(FLOAT型)和双精度浮点数(DOUBLE型). 定点数类型就是DECIMAL型. 二.字节数.取值范围 三.定义语法 1 类据类型 (M,D) M:精度,数据的总长度 D:标度,小数点后的长度 注: 小数点不占长

BigDecimal 高精度计算 熟悉扩展,java除法保留小数问题

java保留两位小数问题: 方式一: 四舍五入  double   f   =   111231.5585;  BigDecimal   b   =   new   BigDecimal(f);  double   f1   =   b.setScale(2,   BigDecimal.ROUND_HALF_UP).doubleValue();  保留两位小数  --------------------------------------------------------------- 方式二

Java精确运算(BigDecimal)

(1).浮点数精确计算 胜利油田三流合一项目中一直存在一个问题,就是每次报表统计的物资金额和实际的金额要差那么几分钱,和实际金额不一致,让客户觉得总是不那么舒服,原因是因为我们使用java的浮点类型double来定义物资金额,并且在报表统计中我们经常要进行一些运算,但Java中浮点数(double.float)的计算是非精确计算,请看下面一个例子: System.out.println(0.05 + 0.01); System.out.println(1.0 - 0.42); System.ou

java double 保留两位小数

java保留两位小数问题: 方式一: 四舍五入  double   f   =   111231.5585;  BigDecimal   b   =   new   BigDecimal(f);  double   f1   =   b.setScale(2,   BigDecimal.ROUND_HALF_UP).doubleValue();  保留两位小数  ---------------------------------------------------------------   方

SQL笔记-第五章,函数

一.数学函数 功能 函数名  用法 绝对值  ABS()    指数  POWER() POWER(FWeight,-0.5)  平方根  SQRT()    求随机数  RAND()    舍入到最大整数  CEILING()    舍入到最小整数  FLOOR()    四舍五入  ROUND(m)    四舍五入  ROUND(m,d)  d是保留的小数位数  正弦  SIN()    余弦  COS ()    反正弦  ASIN()    反余弦  ACOS()    正切  TAN(

【sql学习】sql常用语法汇总

一.字符串函数是oracle使用最广泛的一种函数(表是参考sql查询介绍(二)中的表). A.LOWER(参数):把参数变成小写 例如:查询名称为scott的员工信息 (不区分大小写的查询) SQL> select empno,ename,job,mgr,hiredate,sal,comm,deptno from emp  where lower(ename)='scott'; 输出的结果是: EMPNO ENAME      JOB         MGR HIREDATE         

java.math.BigDecimal保留两位小数,保留小数,精确位数

http://blog.csdn.net/yuhua3272004/article/details/3075436 使用java.math.BigDecimal工具类实现 java保留两位小数问题: 方式一(四舍五入形式保留两位小数,注意模式ROUND_HALF_UP): 四舍五入   double   f   =   111231.5585;   BigDecimal   b   =   new   BigDecimal(f);   double   f1   =   b.setScale(2

PHP学习之输出字符串(echo,print,printf,printr和vardump)

下面一一进行介绍. 1. echo echo 是PHP的一个关键字,它没有返回值.在写法上,它可以省略小括号.如下代码: 复制代码 代码如下: echo 'Test String'; echo('Test String'); 2. print print 也是PHP的一个关键字,它有返回值,一般返回true,返回false的情况应该没有.在写法上,它和echo一样,可以省略小括号.如下代码: 复制代码 代码如下: print 'Test String'; print('Test String')