>웹 프론트엔드 >JS 튜토리얼 >js 부동 소수점 숫자의 정확한 계산

js 부동 소수점 숫자의 정확한 계산

一个新手
一个新手원래의
2017-10-16 10:07:431896검색

//정확한 나눗셈 결과를 얻기 위해 사용되는 나눗셈 함수
//설명: JavaScript의 나눗셈 결과에는 오류가 있으며, 이는 두 개의 부동 소수점 숫자를 나눌 때 더 분명해집니다. 이 함수는 더 정확한 나누기 결과를 반환합니다.
//Call: accp(arg1,arg2)
//반환값: arg1을 arg2로 나눈 정확한 결과

function accp(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);
    }
}

//Number 타입에 p 메소드를 추가해 호출을 더욱 편리하게 합니다.
Number.prototype.p = function (arg){
Return accp(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 = function (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)/m;
}
//给Number类型增加一个add方法,调用起来更加方便。
Number.prototype.add = function (arg){
    return accAdd(arg,this);
}
//减法函数
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 ((arg2*m-arg1*m)/m).toFixed(n);
}
///给number类增加一个sub方法,调用起来更加方便
Number.prototype.sub = function (arg){
    return accSub(arg,this);
}

위 내용은 js 부동 소수점 숫자의 정확한 계산의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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