기본 메서드 호출 시 중간 재정의를 피하는 방법
여러 수준의 클래스 계층 구조로 작업할 때 원하는 상황이 발생할 수 있습니다. 재정의 메서드에서 기본 메서드를 호출하지만 중간 클래스의 구현을 호출하고 싶지는 않습니다. 이 문서에서는 C#에서 이를 달성하는 방법을 살펴보겠습니다.
제공된 코드 조각에는 가상 메서드 Say()가 있는 Base 클래스가 있습니다. 파생 클래스는 이 메서드를 재정의하고 SpecialDerived는 이를 추가로 재정의합니다. SpecialDerived의 인스턴스에 대해 sd.Say()를 호출하면 자체 구현뿐만 아니라 Derived의 구현도 호출된다는 것을 알 수 있습니다.
Derived의 구현이 호출되는 것을 방지하려면 base.base를 사용할 수 없습니다. 말하다(). 대신 다음 두 가지 옵션이 있습니다.
옵션 1: 일반적으로 사용되는 구현을 보호된 가상 메서드로 이동
여러 파생 항목에서 공유해야 하는 일반적으로 사용되는 구현이 있는 경우 클래스를 기본 클래스의 보호된 가상 메서드로 이동합니다. 이렇게 하면 다른 클래스가 중간 클래스의 구현을 호출하지 않고 필요한 구현만 재정의할 수 있습니다.
예를 들어 Derived가 Say()를 재정의하는 대신 보호된 가상 메서드 CustomSay()를 도입할 수 있습니다.
class Base { public virtual void Say() { Console.WriteLine("Called from Base."); } } class Derived : Base { public override void Say() { CustomSay(); base.Say(); } protected virtual void CustomSay() { Console.WriteLine("Called from Derived."); } } class SpecialDerived : Derived { protected override void CustomSay() { Console.WriteLine("Called from Special Derived."); } }
옵션 2: 직접 함수 포인터 호출(안전하지 않음 접근 방식)
대안으로 안전하지 않은 코드 블록을 사용하여 기본 클래스의 메서드에 대한 함수 포인터를 직접 호출할 수 있습니다. 이 접근 방식은 안전하지 않으며 잠재적인 오류가 발생할 수 있으므로 권장되지 않습니다.
class SpecialDerived : Derived { public override void Say() { Console.WriteLine("Called from Special Derived."); var ptr = typeof(Base).GetMethod("Say").MethodHandle.GetFunctionPointer(); var baseSay = (Action)Activator.CreateInstance(typeof(Action), this, ptr); baseSay(); } }
위 내용은 C#에서 재정의할 때 중간 클래스 메서드 호출을 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!