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' 및 'T' 유형에 ' ' 연산자를 적용할 수 없기 때문에 이 코드는 컴파일에 실패합니다.
이 문제를 해결하려면 산술 연산자가 포함된 숫자 유형에 대한 제약 조건이 필요합니다. 불행하게도 C#은 특수한 "IArithmetic" 제약 조건을 제공하지 않습니다.
대안은 산술 연산을 수동으로 처리할 수 있는 '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)(object)(x.ToDouble(NumberFormatInfo.CurrentInfo) + y.ToDouble(NumberFormatInfo.CurrentInfo)); } catch (Exception ex) { throw new ApplicationException("The operation failed.", ex); } }</code>
이 코드는 'string', 'DateTime' 등 지원되지 않는 유형을 확인한 후 'x'와 'y'를 double로 변환하고 산술 연산을 수행한 후 결과를 다시 'T'로 변환합니다.
이 접근 방식을 사용하면 일반 숫자 유형에 대한 산술 연산자를 오버로드할 수 있지만 모든 잠재적 사례를 정상적으로 처리할 수는 없다는 점에 유의하는 것이 중요합니다.
위 내용은 C#에서 일반 숫자 유형에 대한 산술 연산자를 오버로드하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!