C# 일반 숫자 산술 연산자 오버로딩
C#에서는 제네릭 클래스에 대한 산술 연산자를 정의하는 것이 어려울 수 있으며, 특히 제한된 숫자 유형을 처리할 때 더욱 그렇습니다. 구체적인 사례를 연구해 보겠습니다.
문제 설명:
일반 클래스 정의가 주어진 경우:
<code class="language-csharp">public class ConstrainedNumber<T> : IEquatable<ConstrainedNumber<T>>, IEquatable<T>, IComparable<ConstrainedNumber<T>>, IComparable<T>, IComparable where T : struct, IComparable, IComparable<T>, IEquatable<T></code>
이 클래스에 대한 산술 연산자를 어떻게 정의합니까?
실패한 시도:
<code class="language-csharp">public static T operator +(ConstrainedNumber<T> x, ConstrainedNumber<T> y) { return x._value + y._value; }</code>
'T' 및 'T' 유형에는 ' ' 연산자를 적용할 수 없으므로 이 코드는 컴파일되지 않습니다.
산술 연산자의 제약:
이 문제를 해결하려면 산술 연산자를 지원하는 숫자 유형에 대한 제약 조건이 필요합니다. 그러나 C#에서는 이러한 제약 조건을 명시적으로 제공하지 않습니다.
IConvertible을 사용한 솔루션:
대안으로 IConvertible
인터페이스를 제약 조건으로 사용하고 해당 메서드를 사용하여 작업을 수행할 수 있습니다. 예를 들면 다음과 같습니다.
<code class="language-csharp">public static T operator +(T x, T y) where T : IConvertible { var type = typeof(T); if (type == typeof(string) || type == typeof(DateTime)) throw new ArgumentException(string.Format("The type {0} is not supported", type.FullName), "T"); try { return (T)Convert.ChangeType(x.ToDouble(NumberFormatInfo.CurrentInfo) + y.ToDouble(NumberFormatInfo.CurrentInfo), type); } catch (Exception ex) { throw new ApplicationException("The operation failed.", ex); } }</code>
이 솔루션은 IConvertible
인터페이스를 활용하여 값을 double로 변환하고, 연산을 수행하고, 결과를 다시 원래 유형으로 변환합니다. 여기서는 보다 안정적인 유형 변환을 위해 Convert.ChangeType
메서드를 사용합니다.
이 방법은 더 넓은 범위의 유형에 적용할 수 있지만, 완벽하지는 않으며 지정된 유형에 대해 작업이 지원되지 않는 경우 예외가 발생할 수 있다는 점에 유의하는 것이 중요합니다.
위 내용은 C#에서 일반 숫자 클래스에 대한 산술 연산자를 오버로드하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!