>Java >java지도 시간 >Float를 Double로 캐스팅하면 정밀도가 떨어지는 것처럼 보이는 이유는 무엇입니까?

Float를 Double로 캐스팅하면 정밀도가 떨어지는 것처럼 보이는 이유는 무엇입니까?

DDD
DDD원래의
2024-11-01 07:48:02747검색

Why Does Casting a Float to a Double Seem to Reduce Precision?

Float를 Double로 변환할 때 정밀도 유지

특정 시나리오에서는 단순히 float를 double로 캐스팅하면 정밀도가 부정확해 보일 수 있습니다. 이 예상치 못한 동작은 double의 정밀도가 높아져서가 아니라 float의 정밀도가 의도한 값을 정확하게 반영하지 않았기 때문입니다.

이 개념을 이해하려면 다음 예를 고려하세요.

float temp = 14009.35F;
System.out.println(Float.toString(temp)); // Prints 14009.35
System.out.println(Double.toString((double)temp)); // Prints 14009.349609375

float의 문자열 표현은 원하는 정밀도를 갖는 것처럼 보이지만 double의 문자열 표현은 float에 저장된 값을 정확하게 표시합니다. 차이점은 float의 내부 값이 실제 14009.35가 아니라 14009.349609375에 더 가깝기 때문에 발생합니다. float를 double로 캐스팅하면 기본 정밀도가 노출될 뿐입니다.

문자열로 변환하고 그 반대로 변환하는 것은 원하는 정밀도를 유지하는 것처럼 보이기 때문에 실행 가능한 솔루션처럼 보일 수 있습니다.

System.out.println(Double.toString(Double.parseDouble(Float.toString(temp)))); // Prints 14009.35

그러나 , 이 접근 방식은 잠재적인 문제를 야기합니다. 문자열 표현이 실제로 정확하지 않은 경우 정밀도는 달라도 결과 double은 여전히 ​​부정확합니다.

따라서 특정 숫자 요구 사항에 대해 float 및 double 사용의 적합성을 평가하는 것이 중요합니다. 정확한 십진수 값이 필요한 경우에는 BigDecimal이 더 적절한 선택일 수 있습니다. BigDecimal은 임의의 정밀도를 허용하여 부동 소수점 및 이중 표현 제한의 잠재적 위험을 제거합니다.

위 내용은 Float를 Double로 캐스팅하면 정밀도가 떨어지는 것처럼 보이는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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