>  기사  >  웹 프론트엔드  >  JS_javascript 팁의 곱셈에서 부동 소수점 오류를 해결하는 방법

JS_javascript 팁의 곱셈에서 부동 소수점 오류를 해결하는 방법

WBOY
WBOY원래의
2016-05-16 17:05:291315검색

JS에서 소수 곱셈을 수행하면 부동 소수점 오류가 발생합니다. 구체적으로 테스트할 수 있습니다.

<script> <br>경고(11*22.9) <br></script>

결과는 251.9 대신 251.89999999999998입니다.

이 문제는 많은 사람들에게 골칫거리일 것입니다. 그렇다면 어떻게 해결해야 할까요? 여기에 해결책이 있습니다.

1.


코드 복사 코드는 다음과 같습니다.
<script> <br> Alert(11*(22.9*10)/10); <br></script>

문제를 해결하기 위한 일반적인 아이디어는 먼저 인수를 정수로 증폭하는 것입니다. 마지막으로 해당 배수로 나누면 올바른 결과를 얻을 수 있습니다.
2.

코드 복사 코드는 다음과 같습니다.


이 솔루션은 더 까다롭지만 이 문제를 해결하는 실제 프로세스에 대한 개요를 제공할 수 있습니다.
반올림 방법을 사용할 수도 있습니다. js에서 Math.round를 사용하여 소수점까지의 정확도를 달성해야 하는 경우 함수를 작성해야 합니다.


코드 복사 코드는 다음과 같습니다.
function ForDight(Dight,How) {
Dight = Math.round(Dight*Math.pow(10,How))/Math.pow(10,How)
return Dight;
//정확한 나눗셈 결과를 얻기 위해 사용되는 나눗셈 함수
//설명: 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(). 분할 (".")[1].length}catch(e){}
with(Math){
r1=Number(arg1.toString().replace(".",""))
r2=Number(arg2.toString().replace(".",""))
return (r1/r2)*pow(10,t2-t1);
}
}

//Number 유형에 div 메소드를 추가하여 호출을 더욱 편리하게 만듭니다.
Number.prototype.div = 함수(arg){

return accDiv(this, arg);

}

//정확한 곱셈 결과를 얻기 위해 사용되는 곱셈 함수
//설명: JavaScript의 곱셈 결과에는 오류가 있으며, 이는 두 개의 부동 소수점 숫자를 곱할 때 더 분명해집니다. 이 함수는 더 정확한 곱셈 결과를 반환합니다.

//Call: 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)
}

// Number 타입에 mul 메소드를 추가해 더욱 편리하게 전화를 걸 수 있습니다.
Number.prototype.mul = 함수(arg){

return accMul(arg, this);

}

//정확한 덧셈 결과를 얻기 위해 사용되는 덧셈 함수
//설명: JavaScript의 덧셈 결과에는 오류가 있으며, 이는 두 개의 부동 소수점 숫자를 더할 때 더 분명해집니다. 이 함수는 더 정확한 덧셈 결과를 반환합니다.

//Call: 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)/ 음
}

//전화를 더 편리하게 할 수 있도록 Number 유형에 add 메소드를 추가합니다.
Number.prototype.add = 함수(arg){

return accAdd(arg,this);

}


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.