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
인터페이스를 제약 조건으로 사용하고 'T'를 산술 연산 수행에 적합한 유형으로 수동으로 변환할 수 있습니다.
<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)(object)(x.ToDouble(NumberFormatInfo.CurrentInfo) + y.ToDouble(NumberFormatInfo.CurrentInfo)); } catch (Exception ex) { throw new ApplicationException("The operation failed.", ex); } }</code>
이 메서드는 IConvertible
인터페이스를 활용하여 'T'를 double로 변환하고 산술 연산을 수행한 다음 결과를 다시 'T' 유형으로 변환합니다. 그러나 이 접근 방식은 모든 시나리오에 적합하지 않을 수 있으며 애플리케이션의 특정 요구 사항에 따라 사용자 지정해야 할 수도 있다는 점에 유의하는 것이 중요합니다.
위 내용은 산술 연산 지원을 통해 C#의 일반 클래스에 대해 산술 연산자를 오버로드하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!