Lire en anglais

Partager via


MethodBase.IsFinal Propriété

Définition

Obtient une valeur indiquant si cette méthode est final.

C#
public bool IsFinal { get; }

Valeur de propriété

true si cette méthode est final ; sinon false.

Implémente

Exemples

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

C#
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);
    }
}

Remarques

Si la méthode virtuelle est marquée final, elle ne peut pas être remplacée dans les classes dérivées. La méthode virtuelle remplacée peut être marquée final à l’aide des mot clé scellées en C#, notOverridable mot clé en Visual Basic ou mot clé scellées en C++/CLI. La méthode peut également être marquée final implicitement par le compilateur. Par exemple, une méthode peut être définie comme non virtuelle dans votre code, mais elle implémente une méthode d’interface. Le 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.

Vous pouvez utiliser cette propriété, conjointement avec la IsVirtual propriété, pour déterminer si une méthode est substituable. Pour qu’une méthode soit substituable, IsVirtual la propriété doit être true et IsFinal la propriété doit être false. Pour établir avec certitude si une méthode est substituable, utilisez le code suivant :

C#
if (MethodInfo.IsVirtual && !MethodInfo.IsFinal)

Si IsVirtual est false ou IsFinal est true, la méthode ne peut pas être remplacée.

S’applique à

Produit Versions
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Voir aussi