MethodBase.IsVirtual Eigenschaft

Definition

Ruft einen Wert ab, der angibt, ob die Methode virtual ist.Gets a value indicating whether the method is virtual.

public:
 property bool IsVirtual { bool get(); };
public bool IsVirtual { get; }
member this.IsVirtual : bool
Public ReadOnly Property IsVirtual As Boolean

Eigenschaftswert

true, wenn diese Methode virtual ist, andernfalls false.true if this method is virtual; otherwise, false.

Implementiert

Beispiele

Im folgenden Beispiel wird false für IsFinalangezeigt, was Sie möglicherweise dazu führt, dass MyMethod über schreibbar ist.The following example displays false for IsFinal, which might lead you to think that MyMethod is overridable. Der Code druckt false, obwohl MyMethod nicht als virtual gekennzeichnet ist und daher nicht überschrieben werden kann.The code prints false even though MyMethod is not marked virtual and thus cannot be overridden.

using namespace System;
using namespace System::Reflection;

public ref class MyClass
{
public:
   void MyMethod(){}
};

int main()
{
   MethodBase^ m = MyClass::typeid->GetMethod( "MyMethod" );
   Console::WriteLine( "The IsFinal property value of MyMethod is {0}.", m->IsFinal );
   Console::WriteLine( "The IsVirtual property value of MyMethod is {0}.", m->IsVirtual );
}
using System;
using System.Reflection;
 
public class MyClass 
{
    public void MyMethod() 
    {
    }
    public static void Main() 
    {
        MethodBase m = typeof(MyClass).GetMethod("MyMethod");
        Console.WriteLine("The IsFinal property value of MyMethod is {0}.", m.IsFinal);
        Console.WriteLine("The IsVirtual property value of MyMethod is {0}.", m.IsVirtual);
    }
}
Imports System.Reflection

Public Class MyClass1
    
    Public Sub MyMethod()
    End Sub
    
    Public Shared Sub Main()
        Dim m As MethodBase = GetType(MyClass1).GetMethod("MyMethod")
        Console.WriteLine("The IsFinal property value of MyMethod is {0}.", m.IsFinal)
        Console.WriteLine("The IsVirtual property value of MyMethod is {0}.", m.IsVirtual)
    End Sub
End Class

Hinweise

Ein virtuelles Element kann auf Instanzdaten in einer Klasse verweisen, und es muss über eine Instanz der-Klasse auf Sie verwiesen werden.A virtual member may reference instance data in a class and must be referenced through an instance of the class.

Um zu ermitteln, ob eine Methode über schreibbar ist, reicht es nicht aus, zu überprüfen, ob IsVirtual trueist.To determine if a method is overridable, it is not sufficient to check that IsVirtual is true. Damit eine Methode über schreibbar ist, muss IsVirtual true werden, und IsFinal muss falsewerden.For a method to be overridable, IsVirtual must be true and IsFinal must be false. Beispielsweise kann eine Methode nicht virtuell sein, aber Sie implementiert eine Schnittstellen Methode.For example, a method might be non-virtual, but it implements an interface method. Der Common Language Runtime erfordert, dass alle Methoden, die Schnittstellenmember implementieren, als virtualgekennzeichnet werden. Daher markiert der Compiler die Methode virtual final.The common language runtime requires that all methods that implement interface members must be marked as virtual; therefore, the compiler marks the method virtual final. Es gibt Fälle, in denen eine Methode als virtual gekennzeichnet ist, aber immer noch nicht über schreibbar ist.So there are cases where a method is marked as virtual but is still not overridable.

Um sicherzustellen, ob eine Methode über schreibbar ist, verwenden Sie Code wie den folgenden:To establish with certainty whether a method is overridable, use code such as this:

if (MethodInfo.IsVirtual && !MethodInfo.IsFinal)  
If MethodInfo.IsVirtual AndAlso Not MethodInfo.IsFinal Then  

Wenn IsVirtual false oder IsFinal trueist, kann die Methode nicht überschrieben werden.If IsVirtual is false or IsFinal is true, then the method cannot be overridden.

Sie können bestimmen, ob die aktuelle Methode eine Methode in einer Basisklasse überschreibt, indem Sie die MethodInfo.GetBaseDefinition-Methode aufrufen.You can determine whether the current method overrides a method in a base class by calling the MethodInfo.GetBaseDefinition method. Im folgenden Beispiel wird eine IsOverride-Methode implementiert, die dies bewirkt.The following example implements an IsOverride method that does this.

using System;
using System.Reflection;

public class ReflectionUtilities
{   
   public static bool IsOverride(MethodInfo method)
   {
      return ! method.Equals(method.GetBaseDefinition());
   }
}

public class Example
{
   public static void Main()
   {
      MethodInfo equals = typeof(Int32).GetMethod("Equals", 
                                        new Type[] { typeof(Object) } );
      Console.WriteLine("{0}.{1} is inherited: {2}", 
                        equals.ReflectedType.Name, equals.Name,
                        ReflectionUtilities.IsOverride(equals));
      
      equals = typeof(Object).GetMethod("Equals", 
                                        new Type[] { typeof(Object) } );
      Console.WriteLine("{0}.{1} is inherited: {2}", 
                        equals.ReflectedType.Name, equals.Name,
                        ReflectionUtilities.IsOverride(equals));
   }
}
// The example displays the following output:
//       Int32.Equals is inherited: True
//       Object.Equals is inherited: False
Imports System.Reflection

Public Class ReflectionUtilities
   Public Shared Function IsOverride(method As MethodInfo) As Boolean
      Return Not method.Equals(method.GetBaseDefinition())
   End Function
End Class

Module Example
   Public Sub Main()
      Dim equals As MethodInfo = GetType(Int32).GetMethod("Equals", 
                                         { GetType(Object) } )
      Console.WriteLine("{0}.{1} is inherited: {2}", 
                        equals.ReflectedType.Name, equals.Name,
                        ReflectionUtilities.IsOverride(equals))
      
      equals = GetType(Object).GetMethod("Equals", { GetType(Object) } )
      Console.WriteLine("{0}.{1} is inherited: {2}", 
                        equals.ReflectedType.Name, equals.Name,
                        ReflectionUtilities.IsOverride(equals))
   End Sub
End Module
' The example displays the following output:
'       Int32.Equals is inherited: True
'       Object.Equals is inherited: False

Gilt für: