Auf Englisch lesen

Teilen über


Assembly.GetType Methode

Definition

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

Überlädt

GetType(String, Boolean, Boolean)

Ruft das Type-Objekt mit dem angegebenen Namen in der Assemblyinstanz ab, wobei optional die Groß- und Kleinschreibung unberücksichtigt bleiben und optional eine Ausnahme ausgelöst werden kann, wenn der Typ nicht gefunden wurde.

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 wurde.

GetType(String)

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

GetType()

GetType(String, Boolean, Boolean)

Quelle:
Assembly.cs
Quelle:
Assembly.cs
Quelle:
Assembly.cs

Ruft das Type-Objekt mit dem angegebenen Namen in der Assemblyinstanz ab, wobei optional die Groß- und Kleinschreibung unberücksichtigt bleiben und optional eine Ausnahme ausgelöst werden kann, wenn der Typ nicht gefunden wurde.

C#
public virtual Type GetType (string name, bool throwOnError, bool ignoreCase);
C#
public virtual Type? GetType (string name, bool throwOnError, bool ignoreCase);
C#
public Type GetType (string name, bool throwOnError, bool ignoreCase);

Parameter

name
String

Der vollständige Name des Typs.

throwOnError
Boolean

true, damit eine Ausnahme ausgelöst wird, wenn der Typ nicht gefunden wurde. false, damit null zurückgegeben wird.

ignoreCase
Boolean

true, um die Groß- und 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 überschreitet 1024 Zeichen.

name ist null.

throwOnError ist true, und der Typ wurde nicht gefunden.

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 reflektionsbezogenen Kontext geladen, und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

typeName erfordert eine abhängige Assembly, aber die Datei ist keine gültige Assembly für die derzeit geladene Runtime.

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.

Hinweis

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

Der throwOnError Parameter wirkt sich nur darauf aus, was geschieht, wenn der Typ nicht gefunden wird. Dies wirkt sich nicht auf andere Ausnahmen aus, die möglicherweise ausgelöst werden. Insbesondere, wenn der Typ gefunden, aber nicht geladen werden kann, kann auch dann ausgelöst werden, TypeLoadException wenn throwOnError ist false.

Gilt für:

.NET 9 und andere Versionen
Produkt Versionen
.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
.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.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

GetType(String, Boolean)

Quelle:
Assembly.cs
Quelle:
Assembly.cs
Quelle:
Assembly.cs

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

C#
public virtual Type? GetType (string name, bool throwOnError);
C#
public virtual Type GetType (string name, bool throwOnError);

Parameter

name
String

Der vollständige Name des Typs.

throwOnError
Boolean

true, damit eine Ausnahme ausgelöst wird, wenn der Typ nicht gefunden wurde. false, damit null zurückgegeben wird.

Gibt zurück

Ein Objekt, das die angegebene Klasse darstellt.

Implementiert

Ausnahmen

name ist ungültig.

- oder -

Die Länge von name überschreitet 1024 Zeichen.

name ist null.

throwOnError ist true, und der Typ wurde nicht gefunden.

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 reflektionsbezogenen Kontext geladen, und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

typeName erfordert eine abhängige Assembly, aber die Datei ist keine gültige Assembly für die derzeit geladene Runtime.

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.

Hinweis

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

Der throwOnError Parameter wirkt sich nur darauf aus, was geschieht, wenn der Typ nicht gefunden wird. Dies wirkt sich nicht auf andere Ausnahmen aus, die möglicherweise ausgelöst werden. Insbesondere, wenn der Typ gefunden, aber nicht geladen werden kann, kann auch dann ausgelöst werden, TypeLoadException wenn throwOnError ist false.

Gilt für:

.NET 9 und andere Versionen
Produkt Versionen
.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
.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.5, 1.6, 2.0, 2.1

GetType(String)

Quelle:
Assembly.cs
Quelle:
Assembly.cs
Quelle:
Assembly.cs

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

C#
public virtual Type GetType (string name);
C#
public virtual Type? GetType (string name);

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 reflektionsbezogenen Kontext geladen, und name erfordert eine abhängige Assembly, die nicht vorab geladen wurde.

Hinweis: In .NET für Windows Store-Apps oder der portablen Klassenbibliothek sollten Sie stattdessen die Basisklassen-Ausnahme IOExceptionabfangen.

typeName erfordert eine abhängige Assembly, aber die Datei ist keine gültige Assembly für die derzeit geladene Runtime.

Beispiele

Im folgenden Beispiel wird eine abstrakte MeansOfTransportation Klasse im Transportation Namespace definiert. Sie ruft die GetType(String) -Methode auf, um ihr Type -Objekt abzurufen, ruft die 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 (d. a. seinen Namespace zusammen mit dem Typnamen) verwendet.

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

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.

Hinweis

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

Gilt für:

.NET 9 und andere Versionen
Produkt Versionen
.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
.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

GetType()

C#
public Type GetType ();

Gibt zurück

Implementiert

Gilt für:

.NET Framework 1.1
Produkt Versionen
.NET Framework 1.1