Assembly.GetType Methode

Definition

Ruft das Type Objekt ab, das den angegebenen Typ darstellt.

Überlädt

Name Beschreibung
GetType(String, Boolean, Boolean)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab, mit den Optionen zum Ignorieren des Falls und auslösen einer Ausnahme, wenn der Typ nicht gefunden wird.

GetType(String, Boolean)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab und löst optional eine Ausnahme aus, wenn der Typ nicht gefunden wird.

GetType()
GetType(String)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab.

GetType(String, Boolean, Boolean)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab, mit den Optionen zum Ignorieren des Falls und auslösen einer Ausnahme, wenn der Typ nicht gefunden wird.

public:
 virtual Type ^ GetType(System::String ^ name, bool throwOnError, bool ignoreCase);
public virtual Type GetType(string name, bool throwOnError, bool ignoreCase);
public Type GetType(string name, bool throwOnError, bool ignoreCase);
override this.GetType : string * bool * bool -> Type
Public Overridable Function GetType (name As String, throwOnError As Boolean, ignoreCase As Boolean) As Type
Public Function GetType (name As String, throwOnError As Boolean, ignoreCase As Boolean) As Type

Parameter

name
String

Der vollständige Name des Typs.

throwOnError
Boolean

true um eine Ausnahme auszuwerfen, wenn der Typ nicht gefunden wird; false zurückzugeben null.

ignoreCase
Boolean

truedie Groß-/Kleinschreibung des Typnamens zu ignorieren; andernfalls . false

Gibt zurück

Ein Objekt, das die angegebene Klasse darstellt.

Implementiert

Ausnahmen

name ist ungültig.

– oder –

Die Länge von name mehr als 1024 Zeichen.

name ist null.

throwOnError ist true, und der Typ kann nicht gefunden werden.

name erfordert eine abhängige Assembly, die nicht gefunden werden konnte.

name erfordert eine abhängige Assembly, die gefunden wurde, aber nicht geladen werden konnte.

– oder –

Die aktuelle Assembly wurde in den Nur-Spiegelungskontext geladen und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

name erfordert eine abhängige Assembly, die Datei ist jedoch keine gültige Assembly für die derzeit geladene Laufzeit.

Hinweise

Diese Methode durchsucht nur die aktuelle Assemblyinstanz. Der name Parameter enthält den Namespace, aber nicht die Assembly. Um andere Assemblys nach einem Typ zu durchsuchen, verwenden Sie die Type.GetType(String) Methodenüberladung, die optional einen Assemblyanzeigenamen als Teil des Typnamens enthalten kann.

Wenn in .NET Core/.NET 5+ Assembly-qualifizierte generische Typparameter in der Typnamenzeichenfolge vorhanden sind, werden diese Assemblyverweise von der AssemblyLoadContext der Methode geladen, die Assembly.GetType aufgerufen hat, oder vom AssemblyLoadContext.CurrentContextualReflectionContext Kontext, wenn sie festgelegt ist.

Note

Wenn der Typ an eine andere Assembly weitergeleitet wurde, wird er noch von dieser Methode zurückgegeben. Informationen zur Typweiterleitung finden Sie unter "Type Forwarding" in der Common Language Runtime.

Der throwOnError Parameter wirkt sich nur darauf aus, was passiert, wenn der Typ nicht gefunden wird. Es wirkt sich nicht auf andere Ausnahmen aus, die ausgelöst werden können. Insbesondere, wenn der Typ gefunden, aber nicht geladen werden kann, TypeLoadException kann auch bei Bedarf throwOnErrorfalseausgelöst werden.

Gilt für:

GetType(String, Boolean)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab und löst optional eine Ausnahme aus, wenn der Typ nicht gefunden wird.

public:
 virtual Type ^ GetType(System::String ^ name, bool throwOnError);
public virtual Type GetType(string name, bool throwOnError);
override this.GetType : string * bool -> Type
Public Overridable Function GetType (name As String, throwOnError As Boolean) As Type

Parameter

name
String

Der vollständige Name des Typs.

throwOnError
Boolean

true um eine Ausnahme auszuwerfen, wenn der Typ nicht gefunden wird; false zurückzugeben null.

Gibt zurück

Ein Objekt, das die angegebene Klasse darstellt.

Implementiert

Ausnahmen

name ist ungültig.

– oder –

Die Länge von name mehr als 1024 Zeichen.

name ist null.

throwOnError ist true, und der Typ kann nicht gefunden werden.

name erfordert eine abhängige Assembly, die nicht gefunden werden konnte.

name erfordert eine abhängige Assembly, die gefunden wurde, aber nicht geladen werden konnte.

– oder –

Die aktuelle Assembly wurde in den Nur-Spiegelungskontext geladen und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

name erfordert eine abhängige Assembly, die Datei ist jedoch keine gültige Assembly für die derzeit geladene Laufzeit.

Hinweise

Diese Methode durchsucht nur die aktuelle Assemblyinstanz. Der name Parameter enthält den Namespace, aber nicht die Assembly. Um andere Assemblys nach einem Typ zu durchsuchen, verwenden Sie die Type.GetType(String) Methodenüberladung, die optional einen Assemblyanzeigenamen als Teil des Typnamens enthalten kann.

Wenn in .NET Core/.NET 5+ Assembly-qualifizierte generische Typparameter in der Typnamenzeichenfolge vorhanden sind, werden diese Assemblyverweise von der AssemblyLoadContext der Methode geladen, die Assembly.GetType aufgerufen hat, oder vom AssemblyLoadContext.CurrentContextualReflectionContext Kontext, wenn sie festgelegt ist.

Note

Wenn der Typ an eine andere Assembly weitergeleitet wurde, wird er noch von dieser Methode zurückgegeben. Informationen zur Typweiterleitung finden Sie unter "Type Forwarding" in der Common Language Runtime.

Der throwOnError Parameter wirkt sich nur darauf aus, was passiert, wenn der Typ nicht gefunden wird. Es wirkt sich nicht auf andere Ausnahmen aus, die ausgelöst werden können. Insbesondere, wenn der Typ gefunden, aber nicht geladen werden kann, TypeLoadException kann auch bei Bedarf throwOnErrorfalseausgelöst werden.

Gilt für:

GetType()

public:
 virtual Type ^ GetType();
public Type GetType();
override this.GetType : unit -> Type
Public Function GetType () As Type

Gibt zurück

Implementiert

Gilt für:

GetType(String)

Ruft das Type Objekt mit dem angegebenen Namen in der Assemblyinstanz ab.

public:
 virtual Type ^ GetType(System::String ^ name);
public virtual Type GetType(string name);
override this.GetType : string -> Type
Public Overridable Function GetType (name As String) As Type

Parameter

name
String

Der vollständige Name des Typs.

Gibt zurück

Ein Objekt, das die angegebene Klasse darstellt oder null wenn die Klasse nicht gefunden wird.

Implementiert

Ausnahmen

name ist ungültig.

name ist null.

name erfordert eine abhängige Assembly, die nicht gefunden werden konnte.

name erfordert eine abhängige Assembly, die gefunden wurde, aber nicht geladen werden konnte.

– oder –

Die aktuelle Assembly wurde in den Nur-Spiegelungskontext geladen und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

name erfordert eine abhängige Assembly, die Datei ist jedoch keine gültige Assembly für die derzeit geladene Laufzeit.

Beispiele

Im folgenden Beispiel wird eine abstrakte MeansOfTransportation Klasse im Transportation Namespace definiert. Sie ruft die Methode auf, um das Objekt abzurufenType, ruft die GetType(String)Type.GetProperties Methode auf, um ein Array von PropertyInfo Objekten abzurufen, die die Eigenschaften des Typs darstellen, und zeigt dann Informationen zu den abstrakten Eigenschaften des Typs an. Beachten Sie, dass der Aufruf der GetType(String) Methode den vollqualifizierten Namen des Typs verwendet (d. a. seinen Namespace zusammen mit seinem Typnamen).

using System;
using System.Reflection;

public class Example
{
    public static void Main()
    {
        Assembly assem = typeof(Example).Assembly;
        Type t = assem.GetType("Transportation.MeansOfTransportation");
        if (t != null)
        {
            Console.WriteLine($"Virtual properties in type {t.FullName}:");
            PropertyInfo[] props = t.GetProperties();
            int nVirtual = 0;
            for (int ctr = 0; ctr < props.Length; ctr++)
            {
                if (props[ctr].GetMethod.IsVirtual)
                {
                    Console.WriteLine($"   {props[ctr].Name} (type {props[ctr].PropertyType.FullName})");
                    nVirtual++;
                }
            }

            if (nVirtual == 0)
                Console.WriteLine("   No virtual properties");
        }
    }
}

namespace Transportation
{
    public abstract class MeansOfTransportation
    {
        abstract public bool HasWheels { get; set; }
        abstract public int Wheels { get; set; }
        abstract public bool ConsumesFuel { get; set; }
        abstract public bool Living { get; set; }
    }
}
// The example displays the following output:
//    Virtual properties in type Transportation.MeansOfTransportation:
//       HasWheels (type System.Boolean)
//       Wheels (type System.Int32)
//       ConsumesFuel (type System.Boolean)
//       Living (type System.Boolean)
Imports System.Reflection

Module Example
   Public Sub Main()
      Dim assem As Assembly = GetType(Example).Assembly
      Dim t As Type = assem.GetType("Transportation.MeansOfTransportation")
      If Not t Is Nothing Then
         Console.WriteLine("Virtual properties in type {0}:", 
                           t.FullName)
         Dim props() As PropertyInfo = t.GetProperties()
         Dim nVirtual As Integer = 0
         For ctr As Integer = 0 To props.Length - 1
            If props(ctr).GetMethod.IsVirtual Then
               Console.WriteLine("   {0} (type {1})",
                                 props(ctr).Name, 
                                 props(ctr).PropertyType.FullName)
               nVirtual += 1
            End If
         Next
         If nVirtual = 0 Then 
            Console.WriteLine("   No virtual properties")
         End If   
      End If   
   End Sub
End Module

Namespace Transportation
   Public MustInherit Class MeansOfTransportation
      Public MustOverride Property HasWheels As Boolean
      Public MustOverride Property Wheels As Integer
      Public MustOverride Property ConsumesFuel As Boolean
      Public MustOverride Property Living As Boolean
   End Class
End Namespace
' The example displays the following output:
'    Virtual properties in type Transportation.MeansOfTransportation:
'       HasWheels (type System.Boolean)
'       Wheels (type System.Int32)
'       ConsumesFuel (type System.Boolean)
'       Living (type System.Boolean)

Hinweise

Diese Methode durchsucht nur die aktuelle Assemblyinstanz. Der name Parameter enthält den Namespace, aber nicht die Assembly. Um andere Assemblys nach einem Typ zu durchsuchen, verwenden Sie die Type.GetType(String) Methodenüberladung, die optional einen Assemblyanzeigenamen als Teil des Typnamens enthalten kann.

Wenn in .NET Core/.NET 5+ Assembly-qualifizierte generische Typparameter in der Typnamenzeichenfolge vorhanden sind, werden diese Assemblyverweise von der AssemblyLoadContext der Methode geladen, die Assembly.GetType aufgerufen hat, oder vom AssemblyLoadContext.CurrentContextualReflectionContext Kontext, wenn sie festgelegt ist.

Note

Wenn der Typ an eine andere Assembly weitergeleitet wurde, wird er noch von dieser Methode zurückgegeben. Informationen zur Typweiterleitung finden Sie unter "Type Forwarding" in der Common Language Runtime.

Gilt für: