JS 중 부동 소수점 총화

1246 단어 JavaScript
부동 소수점 의 연산 은 업무 에서 비교적 흔히 볼 수 있 는 것 이다. js 부동 소수점 연산 은 여러 개의 소수 가 나타 날 수 있다. 예 를 들 어 0.1 + 0.2 = 0.30000000000000004, 이것 은 연산 할 때 먼저 부동 소수점 을 2 진법 으로 바 꾼 후에 연산 을 하기 때 문 입 니 다. 그러나 어떤 소 수 는 2 진법 인 코딩 후에 무한 순환 이 나타 나 계산 에 오차 가 생 겼 고 다른 프로 그래 밍 언어 에서 도 비슷 한 문제 가 있 습 니 다.
처리 방법 은 다음 과 같다.
1. 2 를 비트 소수 로 유지 하기:
handleDecimals = function (num) {
    let re = /([0-9]+\.[0-9]{2})[0-9]*/;
    let newNum = num.toString().replace(re,"$1");
    return Number(newNum);
}

2. JavaScript 의 toFixed (n) 방법 을 이용 하여 N 비트 소 수 를 직접 얻 습 니 다. 이 방법 은 반올림 입 니 다. 이런 방법 은 정확도 문제 가 존재 하지만 기본적으로 사용 할 수 있 습 니 다.   var num = 0.888888888...;num.toFixed(2) = 0.89;그런데 가끔 문제 가 있어 요. 1.005 toFixed (2) = 1.00.  0.005 toFixed(2)=0.01
3. 연산 이 필요 한 수의 최대 몇 자리 소수점 이 있 는 지 알 면 (0.1 * 10 + 0.2 * 10) / 10 = 0.3;
4. 소수점 자릿수 가 확실 하지 않 을 때: 먼저 숫자 를 문자열 형식 으로 바 꾸 고 소수점 뒤의 자릿수 를 판단 한 다음 에 방법 3 으로 조작 할 수 있 습 니 다. 여기 서 는 덧셈 과 곱셈 이 조금 다 릅 니 다.예:
value = num.toString(); 
if (value.indexOf('.') > 0) {
    length = value.split('.')[1].length;
}

   4. 부동 소수점 라 이브 러 리 를 제3자 가 직접 처리 하여 봉인 해 주 고, 도입 하면 바로 사용 할 수 있 습 니 다.예: number - precision
구체 적 으로 어떤 방법 으로 자신의 업무 장면 에 따라 선택 합 니까?

좋은 웹페이지 즐겨찾기