>Java >java지도 시간 >Float를 Double로 변환하면 정밀도가 향상되는 것처럼 보이는 이유는 무엇입니까?

Float를 Double로 변환하면 정밀도가 향상되는 것처럼 보이는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-03 06:03:02449검색

Why Does Converting a Float to a Double Seem to Increase Precision?

숫자 정밀도 보존: Float를 Double로 변환

기본 데이터 유형으로 작업할 때는 정밀도를 보장하는 것이 중요합니다. float를 double로 변환하면 때때로 의도하지 않은 반올림 오류가 발생할 수 있습니다. 부동 소수점을 double로 직접 캐스팅하면 예에서 설명한 것처럼 예상치 못한 추가 정밀도가 발생할 수 있습니다.

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

이 명백한 "추가" 정밀도는 변환 중에 실제로 얻어지지 않습니다. 대신 플로트가 의도한 숫자를 정확하게 나타내지 못했습니다. 반면에 double은 원래 float의 값을 정확하게 반영합니다. 문자열로 변환되면 double은 float에 있던 "숨겨진" 데이터를 드러냅니다.

다음 예를 고려하세요.

float f = 0.1F;
double d = f;

f 값은 정확히 0.100000234523일 수 있습니다. d는 동일한 값을 가지지만 문자열로 변환하면 이미 존재하는 "추가" 숫자를 표시하여 더 높은 정밀도로 나타납니다.

문자열로 변환한 후 다시 되돌리면 이중 값에 가까워집니다. 원래 float보다 문자열 표현으로 변경되었습니다. 그러나 이는 문자열 값이 실제로 의도한 숫자를 나타내는 경우에만 유리합니다.

BigDecimal이 이 시나리오에 더 적합한 데이터 유형인지 고려해 볼 가치가 있습니다. BigDecimal은 정확한 소수 값을 위해 특별히 설계되어 필요한 정확한 표현으로 작업할 수 있습니다.

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

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