2.3.2 작은 소수 값

부동 소수점 숫자의 부작용
자바스크립트는 현대의 대부분의 프로그래밍 언어들과 마찬가지로 'IEEE 754'표준(부동 소수점 표준)을 따르는데 이는 부동 소수점 계산에 이슈가 생긴다.

0.1 + 0.2; // 0.30000000000000004
0.1 + 0.2 === 0.3; // false

만약 이렇게 소수점 계산을 하고나서 같은지 체크를 하고 싶을 때가 있는데, 상식적으로 사람이 생각한 것과 다른 결과값이 나오기 때문에 저 문제를 해결하는 방법이 필요하다.
이럴 때 Number.EPSILON 을 사용한다.

function numbersCloseEnoughToEqual(a, b) {
  return Math.abs(a - b) < Number.EPSILON;
}
let a = 0.1 + 0.2;
let b = 0.3;

numbersCloseEnoughToEqual(a, b); // true
numbersCloseEnoughToEqual(0.0000001, 0.0000002); // false

Number.EPSILON 폴리필

if (!Number.EPSILON) {
	Number.EPSILON = Math.pow(2,-52);
}

주석 앞에 숫자 클수록 큰 수

// 3 - 컴퓨터가 이해할 수 있는 가장 작은 숫자 단위
Number.EPSILON; // 2.220446049250313e-16

// 5 - 표현할 수 있는 가장 큰 양수 값
Number.MAX_VALUE; // 1.7976931348623157e+308

// 2 - 표현할 수 있는 가장 작은 양수 값
Number.MIN_VALUE; // 5e-324

// 4 - 안전하게 표현할 수 있는 가장 큰 정수 값
Number.MAX_SAFE_INTEGER; // 9007199254740991

// 1 - 안전하게 표현할 수 있는 가장 작은 정수 값
Number.MIN_SAFE_INTEGER; // -9007199254740991

// 크기 비교
const Num = Number;
Num.MIN_SAFE_INTEGER < Num.MIN_VALUE < Num.EPSILON < Num.MAX_SAFE_INTEGER < Num.MAX_VALUE

// 안전하게 표현할 수 있는 수를 넘어가면 오작동한다.
Num.MAX_SAFE_INTEGER + 2 === Num.MAX_SAFE_INTEGER + 1; // true

좋은 웹페이지 즐겨찾기