수치 데이터를 표현할 때 정밀도와 가독성의 균형을 맞추는 것이 어려울 수 있으며, 특히 부동 소수점 숫자를 다룰 때 더욱 그렇습니다. 포인트 번호. 이러한 숫자를 인쇄할 때 문제가 발생하며, 이로 인해 후행 0이나 불필요한 소수 자릿수가 발생하는 경우가 많습니다.
문제:
다음을 포함한 모든 숫자 값을 나타내려면 double 유형을 사용하는 것이 좋습니다. 정수. 그러나 이러한 의사 정수를 double로 인쇄하면 작은 값에 대해 뒤에 0이 오는 문제가 발생합니다.
원하는 출력:
목표는 double을 깔끔하게 인쇄하는 것입니다. 형식, 실제 값의 정밀도를 유지하면서 정수 값의 후행 0을 억제합니다. doubles.
해결책:
이 상황을 효과적으로 처리하려면 double이 최대 2까지의 정수를 정확하게 나타낼 수 있다는 사실을 활용하는 사용자 정의 형식 지정 기능을 구현할 수 있습니다53. fmt(double d)라는 함수는 다음과 같이 작동합니다.
if (d == (long) d) { return String.format("%d", (long) d); } else { return String.format("%s", d); }
이를 사용하면 %d 형식 지정자를 활용하여 의사 정수를 정수로 인쇄할 수 있지만 실제 double은 %s를 사용하여 정밀도를 유지할 수 있습니다. 지정자.
출력 예:
사용자 정의 형식 지정 기능은 다음을 생성합니다. 출력:
232 0.18 1237875192 4.58 0 1.2345
성능 최적화:
문자열 조작을 방지함으로써 fmt 함수는 효율적인 성능을 보장합니다. 대조적으로, 0 자르기에 의존하는 솔루션은 문자열 연산으로 인해 상당한 성능 저하를 초래할 수 있습니다.
위 내용은 불필요한 0을 제거하기 위해 부동 소수점 숫자의 형식을 어떻게 정확하게 지정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!