MethodBase.IsVirtual Propriété

Définition

Obtient une valeur indiquant si la méthode est virtual.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

Valeur de propriété

true si cette méthode est virtual ; sinon false.true if this method is virtual; otherwise, false.

Implémente

Exemples

L’exemple suivant affiche false pour IsFinal, ce qui peut vous amener à penser que MyMethod est substituable.The following example displays false for IsFinal, which might lead you to think that MyMethod is overridable. Le code imprime false même si MyMethod n’est pas marqué virtual et ne peut donc pas être substitué.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

Remarques

Un membre virtuel peut référencer des données d’instance dans une classe et doit être référencé via une instance de la classe.A virtual member may reference instance data in a class and must be referenced through an instance of the class.

Pour déterminer si une méthode est substituable, il n’est pas suffisant de vérifier que IsVirtual est true.To determine if a method is overridable, it is not sufficient to check that IsVirtual is true. Pour qu’une méthode soit substituable, IsVirtual doit être true et IsFinal doit être false.For a method to be overridable, IsVirtual must be true and IsFinal must be false. Par exemple, une méthode peut être non virtuelle, mais elle implémente une méthode d’interface.For example, a method might be non-virtual, but it implements an interface method. L’common language runtime exige que toutes les méthodes qui implémentent des membres d’interface soient marquées comme virtual; par conséquent, le compilateur marque la méthode 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. Dans certains cas, une méthode est marquée comme virtual mais n’est toujours pas substituable.So there are cases where a method is marked as virtual but is still not overridable.

Pour déterminer avec certitude si une méthode est substituable, utilisez un code tel que celui-ci :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  

Si IsVirtual est false ou IsFinal est true, la méthode ne peut pas être substituée.If IsVirtual is false or IsFinal is true, then the method cannot be overridden.

Vous pouvez déterminer si la méthode actuelle se substitue à une méthode dans une classe de base en appelant la méthode MethodInfo.GetBaseDefinition.You can determine whether the current method overrides a method in a base class by calling the MethodInfo.GetBaseDefinition method. L’exemple suivant implémente une méthode IsOverride qui effectue cette.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

S’applique à