加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

js中浮点型运算BUG的解决方法描述

发布时间:2023-09-13 14:17:25 所属栏目:教程 来源:
导读:曾经项目用到过的,之前在网上找到此代码,但在特定条件下除法和加法运算依然会出现BUG个人对此稍作优化

代码如下:

//除法函数,用来得到精确的除法结果

//说明:javascript的除法结果会有误差,在两个浮
曾经项目用到过的,之前在网上找到此代码,但在特定条件下除法和加法运算依然会出现BUG个人对此稍作优化
 
代码如下:
 
//除法函数,用来得到精确的除法结果
 
//说明: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 accMul((r1 / r2),pow(10, t2 - t1));
 
    }
 
}
 
代码如下:
 
//乘法函数,用来得到精确的乘法结果
 
//说明: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)
 
}
 
代码如下:
 
//加法运算中级解决办法
 
function accAdd(arg1, arg2) {  
 
    var r1, r2, m, c;
 
    try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
 
    try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
 
    c = Math.abs(r1 - r2);  
 
    m = Math.pow(10, Math.max(r1, r2))  
 
    if (c > 0) {  
 
        var cm = Math.pow(10, c);  
 
        if (r1 > r2) {  
 
            arg1 = Number(arg1.toString().replace(".", ""));  
 
            arg2 = Number(arg2.toString().replace(".", "")) * cm;  
 
        }  
 
        else {  
 
            arg1 = Number(arg1.toString().replace(".", "")) * cm;  
 
            arg2 = Number(arg2.toString().replace(".", ""));  
 
        }  
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章