>Java >java지도 시간 >불필요한 후행 0을 피하면서 Java에서 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?

불필요한 후행 0을 피하면서 Java에서 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-29 01:09:16176검색

How Can I Precisely Format Floating-Point Numbers in Java While Avoiding Unnecessary Trailing Zeros?

부동 소수점 형식의 정밀도 유지

Java에서는 종종 String.format("%f")을 사용하여 부동 소수점 숫자 형식을 지정합니다. 작은 값 뒤에 원치 않는 소수점 0이 표시됩니다. 이 문제를 해결하기 위해 정수와 double을 구별하고 적절하게 형식을 지정하는 맞춤형 접근 방식이 제안됩니다.

제공된 솔루션은 64비트 double이 특정 범위 내의 정수를 정확하게 나타낼 수 있다는 사실을 활용합니다. double 값이 긴 정수 캐스팅과 동일한지 확인합니다. true인 경우 값은 String.format("%d")을 사용하여 정수로 형식화됩니다. 그렇지 않으면 String.format("%s")을 사용하여 필요한 최소 정밀도로 double 형식으로 형식이 지정됩니다.

이 논리를 통합함으로써 솔루션은 실제 정밀도를 유지하면서 정수 값에서 불필요한 십진수 0을 효과적으로 제거합니다. 더블스. 문자열 조작이 필요하지 않으므로 이와 관련된 성능 손실을 방지할 수 있습니다.

결과적으로 출력은 다음과 같습니다.

232
0.18
1237875192
4.58
0
1.2345

이 접근 방식은 다음에 의존하기 때문에 로케일에 따라 다릅니다. 문자열.형식. 이 방법을 사용할 때 사용자의 로케일 설정에 따라 잠재적인 형식 차이에 유의하세요.

위 내용은 불필요한 후행 0을 피하면서 Java에서 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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