最近做的项目涉及到金额的计算,需要进行小数位处理,由于白码平台默认就是保留两位小数,所以没怎么注意,直到客户反馈了金额计算的bug我才如梦初醒(亏了一毛钱!),原来现在主流的金额取舍规则流行的是欧洲那套“四舍六入五成双”的规则(也叫银行家算法),而平台上使用的是四舍五入!于是我改用编程来计算金额,使用toFixed()方法来取舍。
小知识:
toFixed它是一个四舍六入五成双的诡异的方法(也叫银行家算法),"四舍六入五成双"含义:对于位数很多的近似数,当有效位数确定后,其后面多余的数字应该舍去,只保留有效数字最末一位,这种修约(舍入)规则是“四舍六入五成双”,也即“4舍6入5凑偶”这里“四”是指≤4
时舍去,"六"是指≥6时进上,"五"指的是根据5后面的数字来定,当5后有数时,舍5入1;当5后无有效数字时,需要分两种情况来讲:①5前为奇数,舍5入1;②5前为偶数,舍5不进。(0是偶数)。
本以为万事大吉了,可是呢,客户又亏钱了!仔细深究了下toFixed这个方法,好家伙,这个方法在谷歌浏览器上并没有完全遵守四舍六入五成双的规则,尤其是5后面没有数字的情况: