/**
* 数字的舍入
*
*/
public class Round
{
/**
* 利用java.lang.Math类对数字进行四舍五入
* @param dou 待舍入的数字
* @return 返回舍入后的整数
*/
public static long getTraRoundMath(double dou)
{
//Math.round方法采用首先将dou加上0.5,然后取下整数
//dou = 4.6,首先dou加0.5成5.1,其下整数为5.四舍五入的结果就是5
return Math.round(dou);
}
/**
* 对数字进行四舍五入
* @param dou 待舍入的数字
* @return 返回舍入后的整数
*/
public static long getTraRound(double dou)
{
//四舍五入模式相当于BigDecimal.ROUND_HALF_UP模式
return Round.getIntRound(dou, BigDecimal.ROUND_HALF_UP);
}
/**
* 要求舍入后返回整数类型
* @param dou 待舍入的数字
* @param roundmode 舍入模式
* @return 返回舍入后的整数
*/
public static long getIntRound(double dou,int roundmode)
{
//最后取得BigDecimal对象转化成int并返回
return Round.getRound(dou, 0, roundmode).longValue();
}
/**
* 要求舍入后返回BigDecimal类型
* @param dou 待舍入的数字
* @param scale 返回的BigDecimal对象的标度(scale)
* @param roundmode 舍入模式
* @return 返回舍入结果,一个BigDecimal对象
*/
public static BigDecimal getRound(double dou,int scale,int roundmode)
{
//创建一个新的BigDecimal对象paramNumber,该对象的值和dou大小一样
BigDecimal paramNumber = new BigDecimal(dou);
//然后调用paramNumber的setScale方法,该方法返回一个BigDecimal对象temp
//返回值的标度为第一个参数指定的值,标度为大小,表示小数部分的位数
//第二个参数指定了paramNumber对象到temp对象的舍入模式,如四舍五入等
return paramNumber.setScale(scale, roundmode);
//可以用一条语句实现:
//return new BigDecimal(dou).setScale(0,roundmode);
}
public static void main(String args[])
{
double dou1 = 8.50;
double dou2 = -9.54;
System.out.println("待舍入的数字dou1 = " + dou1 + "; dou2 = " + dou2);
System.out.println("采用Math类实现四舍五入的结果:\t" + Round.getTraRoundMath(dou1)
+ "\t" + Round.getTraRoundMath(dou2));
System.out.println("四舍五入后的结果:\t" + Round.getTraRound(dou1)
+ "\t" + Round.getTraRound(dou2));
System.out.println("要求舍入后返回整数:");
//接近正无穷大的舍入模式
System.out.println("舍入模式ROUND_CEILING:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_CEILING)
+ "\t" + Round.getIntRound(dou2, BigDecimal.ROUND_CEILING));
//接近零的舍入模式
System.out.println("舍入模式ROUND_DOWN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_DOWN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_DOWN));
//舍入远离零的舍入模式
System.out.println("舍入模式ROUND_UP:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_UP) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_UP));
//接近负无穷大的舍入模式
System.out.println("舍入模式ROUND_FLOOR:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_FLOOR) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_FLOOR));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则为ROUND_DOWN舍入模式
System.out.println("舍入模式ROUND_HALF_DOWN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_DOWN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_DOWN));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入
System.out.println("舍入模式ROUND_HALF_EVEN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_EVEN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_EVEN));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则为ROUND_UP舍入模式
System.out.println("舍入模式ROUND_HALF_UP:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_UP) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_UP));
System.out.println();
System.out.println("要求舍入后返回数字的小数部分保留一位:");
System.out.println("舍入模式ROUND_CEILING:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_CEILING)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_CEILING));
System.out.println("舍入模式ROUND_DOWN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_DOWN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_DOWN));
System.out.println("舍入模式ROUND_UP:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_UP)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_UP));
System.out.println("舍入模式ROUND_FLOOR:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_FLOOR)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_FLOOR));
System.out.println("舍入模式ROUND_HALF_DOWN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_DOWN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_DOWN));
System.out.println("舍入模式ROUND_HALF_EVEN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_EVEN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_EVEN));
System.out.println("舍入模式ROUND_HALF_UP:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_UP)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_UP));
}
}
分享到:
相关推荐
下面小编就为大家带来一篇js数字舍入误差以及解决方法(必看篇)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
oracle 数字的四舍五入、去尾、收尾法
对于位数很多的近似数,当有效位数确定后,其后面多余的数字应该舍去,只保留有效数字最末一位,这种修约(舍入)规则是“四舍六入五成双”,也即“4舍6入5凑偶”,这里“四”是指≤4 时舍去,"六"是指≥6时进上,...
浮点数任意保留数位小数但不需四舍五入小程序
日常接触的数据有正确数和近似数之分,不带测量误差的数均为正确数,接近但不等于某一数的数,称为该数的近似数.
C# 截取小数,不四舍五入,根据传入的变量,设定需要保留金额的位数,并且不四舍五入
在某些行业,计算结果不是四舍五入,而是要求四舍六入五单双,且小数位数不固定,只明确有效位数。本程序就是应此需求而设计,输入原始数字和有效位数要求,则可返回按四舍六入后的结果。
NULL 博文链接:https://eddysoft.iteye.com/blog/2101693
圆角固定的正确将JavaScript数字四舍五入到固定的小数位数概述round-tofixed解决了在JavaScript中舍入十进制数字时的常见问题: Math.round()内置函数只能四舍五入为整数常用的十进制数字舍入方法会产生错误的结果...
舍入规则控制:当需要精确控制数字舍入规则时,如货币计算、统计分析等。 随机数生成:当需要生成伪随机数以支持随机性需求时,如游戏开发、密码生成等。 目标: 理解BigDecimal类的使用,并了解如何处理大数精度...
ROUND63将数值舍入到IEC 60063定义的电子元件值(电阻器、电容器和电感器值的首选数字,以前为IEC 63)。默认情况下,舍入箱边缘近似于组件公差边界,可选输入选择舍入到最近值、向上舍入和向下舍入。支持E系列E3、E6...
mongo-round 使用时执行数字舍入的辅助函数。 npm install mongo-round用法 var round = require ( 'mongo-round' ) ; 零小数位: db . myCollection . aggregate ( [{ $project : {roundValue : round ( '$value' )...
数字修约规则-----四舍五入和四舍六入五留双规则[文].pdf
四舍五入转换程序(VB6.0代码编写) 四舍五入转换 On Error GoTo cw Text2.Text = CInt(Text1.Text) Exit Sub cw: Text2.Text = "输入不是数字" QQ223857666勾月
VB.NET支持四舍五入的计算器,界面是仿Windows计算器风格,功能方面不算很强大,只是常规的数学运算。不过本代码中的注释非常多,对学习VB.NET编程相当有帮助。以下是编写计算器时的一些参数定义: Private sts As...
关于java四舍五入的代码。需要的朋友可以看看。
js数字四舍五入 返回数字指定位数,不足补0 返回字符串指定位数,不足补0.docxjs数字四舍五入 返回数字指定位数,不足补0 返回字符串指定位数,不足补0.docx
如何使得js能够将数字进行四舍五入,根据需求来取相应的位数
这个小函数将一个数字(或向量 ot 矩阵的元素)四舍五入到最近的具有 N 个有效数字的数字。 例子: roundsd(0.012345,3) 返回 0.0123 roundsd(12345,2) 返回 12000 roundsd(12.345,4,'ceil') 返回 12.35 这是对...