MethodBase.IsVirtual Propriété

Définition

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

Implémente

Exemples

L’exemple suivant s’affiche false pour IsFinal, ce qui peut vous conduire à penser qu’il MyMethod est substituable. Le code imprime false même s’il MyMethod n’est pas marqué virtual et ne peut donc pas être remplacé.

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.

Pour déterminer si une méthode est substituable, il n’est pas suffisant de vérifier qu’elle IsVirtual est true. Pour qu’une méthode soit substituable, IsVirtual doit être true et IsFinal doit être false. Par exemple, une méthode peut être non virtuelle, mais elle implémente une méthode d’interface. Le Common Language Runtime requiert 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. Il existe donc des cas où une méthode est marquée comme virtual étant mais n’est toujours pas substituable.

Pour établir avec certitude si une méthode est substituable, utilisez du code tel que celui-ci :

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

Si IsVirtual c’est falseIsFinal le true cas, la méthode ne peut pas être substituée.

Vous pouvez déterminer si la méthode actuelle remplace une méthode dans une classe de base en appelant la MethodInfo.GetBaseDefinition méthode. L’exemple suivant implémente une IsOverride méthode qui effectue cette opération.

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 à