js计算精度问题
//问题比如:7*0.8 JavaScript算出来就是:5.6000000000000005 //加法函数,用来得到精确的加法结果 //说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。 //调用:accAdd(arg1,arg2) //返回值:arg1加上arg2的精确结果 function accAdd(arg1, arg2) { var r1, r2, m; try { r1 = arg1.toString().split( "." )[1].length } catch (e) { r1 = 0 } try { r2 = arg2.toString().split( "." )[1].length } catch (e) { r2 = 0 } m = Math.pow(10, Math.max(r1, r2)) return (arg1 * m + arg2 * m) / m } //用法: //给Number类型增加一个add方法,调用起来更加方便。 Number.prototype.add = function (arg) { return accAdd(arg, this ); } //如: var t1 = 6.60; var t2 = 1.32; var t3 = 1.2; var t4 = 1.2; var t5 = 1.2; alert(Number(t1).add(Number(t2)).add(Number(t3)).add(Number(t4)).add(Number(t5))); //减法函数,用来得到精确的减法结果 function Subtr(arg1, arg2) { var r1, r2, m, n; try { r1 = arg1.toString().split( "." )[1].length } catch (e) { r1 = 0 } try { r2 = arg2.toString().split( "." )[1].length } catch (e) { r2 = 0 } m = Math.pow(10, Math.max(r1, r2)); //last modify by deeka //动态控制精度长度 n = (r1 >= r2) ? r1 : r2; return ((arg1 * m - arg2 * m) / m).toFixed(n); } //乘法函数,用来得到精确的乘法结果 //说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。 //调用:accMul(arg1,arg2) //返回值:arg1乘以arg2的精确结果 function accMul(arg1, arg2) { var m = 0, s1 = arg1.toString(), s2 = arg2.toString(); try { m += s1.split( "." )[1].length } catch (e) { } try { m += s2.split( "." )[1].length } catch (e) { } return Number(s1.replace( "." , "" )) * Number(s2.replace( "." , "" )) / Math.pow(10, m) } //用法: //给Number类型增加一个mul方法,调用起来更加方便。 Number.prototype.mul = function (arg) { return accMul(arg, this ); } //除法函数,用来得到精确的除法结果 //说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。 //调用:accDiv(arg1,arg2) //返回值:arg1除以arg2的精确结果 function accDiv(arg1, arg2) { var t1 = 0, t2 = 0, r1, r2; try { t1 = arg1.toString().split( "." )[1].length } catch (e) { } try { t2 = arg2.toString().split( "." )[1].length } catch (e) { } with (Math) { r1 = Number(arg1.toString().replace( "." , "" )) r2 = Number(arg2.toString().replace( "." , "" )) return (r1 / r2) * pow(10, t2 - t1); } } //用法: //给Number类型增加一个div方法,调用起来更加方便。 Number.prototype.div = function (arg) { return accDiv( this , arg); } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端