js에서 부동 소수점 연산을 수행할 때 정밀도 문제가 발생하기 쉽습니다.
1. 나눗셈 기능
//설명: javascript의 나눗셈 결과에는 오류가 있을 것입니다. 이는 두 개의 부동 소수점 숫자를 나눌 때 더 분명해집니다. 이 함수는 더 정확한 나눗셈 결과를 반환합니다.
//Call: 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); //---整数相除 在乘上10的平方 小数点的长度
}
}
2. 곱셈 기능
//설명: 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)
}
**
3. 덧셈 기능
**
//설명: 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
}
4. 빼기 기능
function accSub(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);
}