js加减乘除精确运算方法实例代码
(编辑:jimmy 日期: 2024/12/26 浏览:3 次 )
前言
因为计算机数字是浮点型,所以在计算过程中通常得到的并不是一个准确的数据,所以在做一些数组运算的时候比较头疼,我们这里就来写一下精确运算的方法
首先是加法 (这里以两个数据相加为例)
function add(arg1, arg2) { arg1 = arg1.toString(), arg2 = arg2.toString(); // 将传入的数据转化为字符串 var arg1Arr = arg1.split("."), // 将小数的数据从小数点的位置拆开 arg2Arr = arg2.split("."), d1 = arg1Arr.length == 2 "", // 获取第一个数的小数点的长度 d2 = arg2Arr.length == 2 ""; // 获取第二个数的小数点的长度 var maxLen = Math.max(d1.length, d2.length); // 获取小数点长度较大的值 var m = Math.pow(10, maxLen); // 这里表示10的小数点长度次方 也就是说如果小数点长度为2 m的值就是100 如果小数点长度是3 m的值就是1000如果不懂请自行查找api var result = Number(((arg1 * m + arg2 * m) / m).toFixed(maxLen)); // 将小数转化为整数后相加在除掉两个数乘过的倍数然后去小数点较长的长度的小数位数 var d = arguments[2]; // 第三个参数用户可以自行决定是否要传递 用来定义要保留的小数长度 return typeof d === "number" "htmlcode">function sun(arg1, arg2) { return add(arg1, -arg2) }其次是乘法
function mul(arg1, arg2) { var r1 = arg1.toString(), // 将传入的数据转化为字符串 r2 = arg2.toString(), m, resultVal, d = arguments[2]; m = (r1.split(".")[1] ".")[1].length : 0) + (r2.split(".")[1] ".")[1].length : 0); // 获取两个数字的小数位数的和 // 乘积的算法就是去掉小数点做整数相乘然后除去10的所有小数位的次方 resultVal = Number(r1.replace(".", "")) * Number(r2.replace(".", "")) / Math.pow(10, m); return typeof d !== "number" "htmlcode">function div(arg1, arg2) { var r1 = arg1.toString(), r2 = arg2.toString(), m, resultVal, d = arguments[2]; m = (r2.split(".")[1] ".")[1].length : 0) - (r1.split(".")[1] ".")[1].length : 0); resultVal = Number(r1.replace(".", "")) / Number(r2.replace(".", "")) * Math.pow(10, m); return typeof d !== "number" ? Number(resultVal) : Number(resultVal.toFixed(parseInt(d))); }总结
下一篇:nodejs中的异步编程知识点详解
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。