计算机在计算时会把数字转化为二进制来计算,此时只能模仿十进制进行四舍五入,但是二进制只有 0 和 1 两个,于是变为 0 舍 1 入。这是浮点数运算时出现误差,丢失精度的原因。
为了解决这些问题,我们可以把浮点数乘以一个数,时期变为整数再进行运算,之后再除以这个数,恢复原来的大小来解决浮点数计算精度缺失的问题,下面是我总结的一些代码,可以直接拿来当模板用。
// 加法
numAdd (num1, num2) {
let baseNum, baseNum1, baseNum2
try {
baseNum1 = num1.toString().split('.')[1].length
} catch (e) {
baseNum1 = 0
}
try {
baseNum2 = num2.toString().split('.')[1].length
} catch (e) {
baseNum2 = 0
}
baseNum = Math.pow(10, Math.max(baseNum1, baseNum2))
return Math.round(num1 * baseNum + num2 * baseNum) / baseNum
},
// 减法
accSub (num1, num2) {
let r1, r2, m, n
try {
r1 = num1.toString().split('.')[1].length
} catch (e) {
r1 = 0
}
try {
r2 = num2.toString().split('.')[1].length
} catch (e) {
r2 = 0
}
m = Math.pow(10, Math.max(r1, r2))
n = (r1 >= r2) ? r1 : r2
return (Math.round(num1 * m - num2 * m) / m).toFixed(n)
},
// 乘法
accMul (num1, num2) {
let m, s1, s2
m = 0
s1 = num1.toString()
s2 = num2.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)
},
// 除法
accDiv (num1, num2) {
let t1, t2, r1, r2
try {
t1 = num1.toString().split('.')[1].length
} catch (e) {
t1 = 0
}
try {
t2 = num2.toString().split('.')[1].length
} catch (e) {
t2 = 0
}
r1 = Number(num1.toString().replace('.', ''))
r2 = Number(num2.toString().replace('.', ''))
return (r1 / r2) * Math.pow(10, t2 - t1)
}