부동 소수점 형식의 정밀도 유지
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!