MethodBase.IsVirtual Свойство

Определение

Получает значение, указывающее, имеет ли метод значение 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

Значение свойства

Boolean

true, если этот метод имеет значение virtual. В противном случае — false.true if this method is virtual; otherwise, false.

Реализации

Примеры

В следующем примере отображается false для IsFinal , что может привести к появлению MyMethod переопределения.The following example displays false for IsFinal, which might lead you to think that MyMethod is overridable. Код печатается несмотря на то, что false MyMethod не помечен virtual и поэтому не может быть переопределен.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

Комментарии

Виртуальный член может ссылаться на данные экземпляра в классе и должен ссылаться через экземпляр класса.A virtual member may reference instance data in a class and must be referenced through an instance of the class.

Чтобы определить, является ли метод переопределяемым, недостаточно проверить, что он IsVirtual имеет значение true .To determine if a method is overridable, it is not sufficient to check that IsVirtual is true. Чтобы метод можно было переопределять, он IsVirtual должен иметь значение true и IsFinal быть false .For a method to be overridable, IsVirtual must be true and IsFinal must be false. Например, метод может быть не виртуальным, но он реализует метод интерфейса.For example, a method might be non-virtual, but it implements an interface method. Среда CLR требует, чтобы все методы, реализующие члены интерфейса, были помечены как virtual , поэтому компилятор помечает метод 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. В некоторых случаях метод помечен как, virtual но по-прежнему не может быть переопределяемым.So there are cases where a method is marked as virtual but is still not overridable.

Чтобы точно установить, является ли метод переопределяемым, используйте следующий код: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  

Если IsVirtual имеет значение false или IsFinal , то true метод не может быть переопределен.If IsVirtual is false or IsFinal is true, then the method cannot be overridden.

Можно определить, переопределяет ли текущий метод метод в базовом классе, вызвав MethodInfo.GetBaseDefinition метод.You can determine whether the current method overrides a method in a base class by calling the MethodInfo.GetBaseDefinition method. В следующем примере реализуется IsOverride метод, который делает это.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

Применяется к