개요:
.NET에서 배정밀도 부동 소수점 숫자를 문자열로 직접 변환하면 과학적 표기법이 생성될 수 있습니다. 이는 정확한 십진수 표현이 필요한 상황에서는 바람직하지 않습니다. 이 기사에서는 복잡한 문자열 조작이나 정규식에 의존하지 않고 이를 달성할 수 있는 간단한 방법을 제시합니다.
해결책:
솔루션의 핵심은 신중하게 제작된 형식 문자열과 함께 ToString()
메서드를 활용하는 것입니다.
<code class="language-csharp">doubleValue.ToString("0." + new string('#', 339))</code>
설명:
"0."
: 이 부분은 숫자의 정수 부분이 0이더라도 항상 최소한 0으로 표시되도록 보장합니다.new string('#', 339)
: 339개의 '#' 문자를 포함하는 문자열을 동적으로 생성합니다. 형식 문자열의 '#' 문자는 숫자에 대한 자리 표시자 역할을 하며 중요한 경우에만 표시합니다. 339는 double에 대해 가능한 최대 소수점 정밀도를 수용하여 과학적 표기법을 방지하기 위해 선택되었습니다.이 접근 방식은 숫자를 자를 수 있는 간단한 방법과 달리 정밀도 손실 없이 모든 유효한 double 값을 처리합니다. 형식 지정은 .NET 프레임워크 내에서 효율적으로 수행되므로 수동 문자열 조작에 비해 성능이 뛰어납니다.
최적화된 코드:
가독성과 성능을 향상하려면 상수를 정의하세요.
<code class="language-csharp">public static class FormatStrings { public const string DoubleFixedPoint = "0.###################################################################################################################################################################################################################################################################################################################################################"; }</code>
그런 다음 다음과 같이 사용하세요.
<code class="language-csharp">doubleValue.ToString(FormatStrings.DoubleFixedPoint);</code>
중요 고려사항:
이 기술은 과학적 표기법을 효과적으로 방지하지만 왕복을 보장하지 않는다는 점을 이해하는 것이 중요합니다. 결과 문자열을 다시 double로 변환하면 부동 소수점 표현의 고유한 제한으로 인해 정확한 원래 값이 생성되지 않을 수 있습니다. 완벽한 왕복이 필요한 상황에서는 사용자 정의 형식 옵션이나 대체 데이터 유형을 살펴보세요.
위 내용은 과학적 표기법 없이 .NET에서 Double을 문자열로 변환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!