js乘法精度计算代码 求解释

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js乘法精度计算代码 求解释相关的知识,希望对你有一定的参考价值。

//乘法函数,用来得到精确的乘法结果
//说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
//调用:accMul(arg1,arg2)
//返回值:arg1乘以arg2的精确结果
function accMul(arg1,arg2)

var m=0,s1=arg1.toString(),s2=arg2.toString();
trym+=s1.split(".")[1].lengthcatch(e)
trym+=s2.split(".")[1].lengthcatch(e)
return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)

求解释两个try语句内代码含义
经过两个try语句后,m值不就是第二个代码的值了么。 这样最后计算就可能出错啊,但实际运行这是个正确的方法,不懂,求解释!
我自己想通了 ,, 通过第二个语句m值不是第二个小数的小数位数,而是变为两个小说的位数之和。

try只是捕获错误,被try包围的语句如果出错了也会继续执行下面的。


这里try里面的语句是获取小数位的长度,假如s1是整数的话s1.split(".")[1].length这句会出错。所以忽略这句,继续执行下面的。


如果不用try的话可以改成下面的

function accMul(arg1, arg2) 
    var m = 0,
        s1 = arg1.toString(),
        s2 = arg2.toString(),
        t;

    t = s1.split(".");
    // 判断有没有小数位,避免出错
    if (t[1]) 
        m += t[1].length
    

    t = s2.split(".");
    if (t[1]) 
        m += t[1].length
    

    return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)

追问

谢谢你。 百度给我了个推荐答案,就没注意其它的。其实该选你为答案的

追答

那赞一个呗,o(∩_∩)o 哈哈

追问

你给我解释清楚了try catch。谢谢!

参考技术A

js含有小数的计算都会有丢失精度的问题


实际上解决的办法就是

把小数转化为整数计算 并同时记住扩大的倍数

最后把结果缩小这个倍数 得到不丢失精度的结果

try catch 就是捕获异常 如果没有捕获肯定会报错

也就是你现在按流程所设想的

但是catch(e)  是捕获了异常 但是里面并没有任何操作

也就是 越过去了 忽略掉

// 这句就是像将小数点去掉 变成整数 如果没有小数点那就没有变化
// 然后计算之后 缩小 10的m次方倍  也就是之前扩大了的倍数
Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)

追问

原理我明白。你回答的和我问的不是一回事。 不过还是谢谢你!

本回答被提问者和网友采纳
参考技术B 注意 第二个try 中用的是m+=而不是 m=.所以实际上 执行两个try 之后m的值是两个浮点数小数位数的和,例arg1=2.3 arg2=3.456 那么就是4,也就是说精确到小数后为,但是实际计算后只能小数只有3位 所以就显示到后三位了追问

谢谢你。百度怎么给了我个推荐答案啊,我就把它选了,没看见后面的回答。。 不然在你和上面这个哥们选一个了。 谢谢你能仔细看我代码!

js 中Math.round()精度问题?急

在下面的代码中,如果输入7位(0.0000007)及7位以上的(0.00000008)小数(即小数最后一位不是0其它位数都是0)时,返回的值就会变成科学计数法,请教这是个什么问题?该怎么解决 ?谢谢! <script type="text/javascript"> function _round() var v =document.getElementById("testValue").value ; var splitStr = v.split("."); var xs = splitStr[1]; var e = -1 ; if(e == -1) if(xs!=null) e = xs.length; else e = 0; var t = 1; for (; e > 0; t *= 10, e--); for (; e < 0; t /= 10, e++); var finalValue = Math.round(v * t) / t ; alert(finalValue) ; ; </script> </head> <body> <input type="text" id="testValue" value=""> <input type="button" value="测试" onClick="_round()"> </body>

参考技术A 不是BUG,最简单的alert(0.56*100);。JavaScript小数在做四则运算时,精度会丢失。
具体可参考IEEE
754的浮点计数法

以上是关于js乘法精度计算代码 求解释的主要内容,如果未能解决你的问题,请参考以下文章

求助 c语言实现高精度乘法

高精度计算 /*高精度的乘法运算*/

js 小数加法的精度问题解决(0.1+0.2 != 0.3,怎么解决?)

关于js中小数运算丢失精度的处理办法

高精度计算:大整数乘法(采用“万进制”)

『数论』乘法逆元