Double에서 소수점 자리를 이동하려면 본능적으로 0.1을 곱할 수도 있습니다. 그러나 0.1은 이진수로 정확하게 표현되지 않기 때문에 반올림 오류가 발생할 수 있습니다.
0.1을 사용하는 대신 정확하게 표현할 수 있는 100을 사용하는 것이 좋습니다. 바이너리로. 소수점 자리를 옮기려면 100으로 나누면 됩니다.
double x = 1234; x /= 100;
이 접근 방식을 사용하더라도 부동 소수점의 한계로 인해 일부 반올림 오류가 여전히 존재합니다. 대표. Double.toString()은 일부 반올림을 수행하지만 반올림을 모두 피하려면 BigDecimal을 사용해야 하는 경우가 많습니다.
x/100과 x * 0.01은 그렇지 않습니다. 반올림 오류 측면에서 동일합니다. 첫 번째 표현식의 반올림 오류는 x 값에 따라 달라지지만 두 번째 표현식의 0.01은 고정된 반올림 오류를 갖습니다. 이는 특정 경우에 다른 결과를 초래할 수 있습니다.
부동 소수점 표현의 한계를 이해하고 적절한 기술을 사용하면 복식에서 소수 자릿수를 정확하게 처리하고 반올림 오류를 최소화할 수 있습니다. 부정확한 곱셈 연산으로 인해 발생합니다.
위 내용은 반올림 오류 없이 Double에서 소수 자릿수를 정확하게 이동하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!