Assembly.GetType Metodo

Definizione

Ottiene l'oggetto Type che rappresenta il tipo specificato.

Overload

GetType(String, Boolean, Boolean)

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly, con la possibilità di ignorare la distinzione tra maiuscole e minuscole e di generare un'eccezione se il tipo non viene trovato.

GetType(String, Boolean)

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly e facoltativamente genera un'eccezione se il tipo non viene trovato.

GetType(String)

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly.

GetType()

GetType(String, Boolean, Boolean)

Origine:
Assembly.cs
Origine:
Assembly.cs
Origine:
Assembly.cs

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly, con la possibilità di ignorare la distinzione tra maiuscole e minuscole e di generare un'eccezione se il tipo non viene trovato.

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);

Parametri

name
String

Nome completo del tipo.

throwOnError
Boolean

true per generare un'eccezione se il tipo non viene trovato; false per restituire null.

ignoreCase
Boolean

true per ignorare la distinzione tra maiuscole e minuscole nel nome del tipo; in caso contrario, false.

Restituisce

Oggetto che rappresenta la classe specificata.

Implementazioni

Eccezioni

name non è valido.

-oppure-

La lunghezza name supera i 1024 caratteri.

name è null.

throwOnError è true e il tipo non è stato trovato.

name richiede un assembly dipendente che non è stato trovato.

name richiede un assembly dipendente che è stato trovato ma che non è stato possibile caricare.

-oppure-

L'assembly corrente è stato caricato nel contesto di sola reflection e name richiede un assembly dipendente che non è stato precaricato.

typeName richiede un assembly dipendente, ma il file non è un assembly valido per il runtime attualmente caricato.

Commenti

Questo metodo esegue solo ricerche nell'istanza dell'assembly corrente. Il name parametro include lo spazio dei nomi ma non l'assembly. Per cercare altri assembly per un tipo, usare l'overload del metodo, che può facoltativamente includere un nome visualizzato dell'assembly Type.GetType(String) come parte del nome del tipo.

Nota

Se il tipo è stato inoltrato a un altro assembly, viene comunque restituito da questo metodo. Per informazioni sull'inoltro dei tipi, vedere Inoltro dei tipi in Common Language Runtime.

Il throwOnError parametro influisce solo su ciò che accade quando il tipo non viene trovato. Non influisce su altre eccezioni che potrebbero essere generate. In particolare, se il tipo viene trovato ma non può essere caricato, TypeLoadException può essere generato anche se throwOnError è false.

Si applica a

.NET 9 e altre versioni
Prodotto Versioni
.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)

Origine:
Assembly.cs
Origine:
Assembly.cs
Origine:
Assembly.cs

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly e facoltativamente genera un'eccezione se il tipo non viene trovato.

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

Parametri

name
String

Nome completo del tipo.

throwOnError
Boolean

true per generare un'eccezione se il tipo non viene trovato; false per restituire null.

Restituisce

Oggetto che rappresenta la classe specificata.

Implementazioni

Eccezioni

name non è valido.

-oppure-

La lunghezza name supera i 1024 caratteri.

name è null.

throwOnError è true e il tipo non è stato trovato.

name richiede un assembly dipendente che non è stato trovato.

name richiede un assembly dipendente che è stato trovato ma che non è stato possibile caricare.

-oppure-

L'assembly corrente è stato caricato nel contesto di sola reflection e name richiede un assembly dipendente che non è stato precaricato.

typeName richiede un assembly dipendente, ma il file non è un assembly valido per il runtime attualmente caricato.

Commenti

Questo metodo esegue solo ricerche nell'istanza dell'assembly corrente. Il name parametro include lo spazio dei nomi ma non l'assembly. Per cercare altri assembly per un tipo, usare l'overload del metodo, che può facoltativamente includere un nome visualizzato dell'assembly Type.GetType(String) come parte del nome del tipo.

Nota

Se il tipo è stato inoltrato a un altro assembly, viene comunque restituito da questo metodo. Per informazioni sull'inoltro dei tipi, vedere Inoltro dei tipi in Common Language Runtime.

Il throwOnError parametro influisce solo su ciò che accade quando il tipo non viene trovato. Non influisce su altre eccezioni che potrebbero essere generate. In particolare, se il tipo viene trovato ma non può essere caricato, TypeLoadException può essere generato anche se throwOnError è false.

Si applica a

.NET 9 e altre versioni
Prodotto Versioni
.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)

Origine:
Assembly.cs
Origine:
Assembly.cs
Origine:
Assembly.cs

Ottiene l'oggetto Type con il nome specificato nell'istanza dell'assembly.

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

Parametri

name
String

Nome completo del tipo.

Restituisce

Oggetto che rappresenta la classe specificata o null se la classe non viene trovata.

Implementazioni

Eccezioni

name non è valido.

name è null.

name richiede un assembly dipendente che non è stato trovato.

name richiede un assembly dipendente che è stato trovato ma che non è stato possibile caricare.

-oppure-

L'assembly corrente è stato caricato nel contesto di sola reflection e name richiede un assembly dipendente che non è stato precaricato.

Nota: in .NET per le app di Windows Store o la libreria di classi portabili, rilevare invece l'eccezione della classe di base, , IOException.

typeName richiede un assembly dipendente, ma il file non è un assembly valido per il runtime attualmente caricato.

Esempio

Nell'esempio seguente viene definita una classe astratta MeansOfTransportation nello Transportation spazio dei nomi. Chiama il metodo per recuperare Type l'oggetto, chiama il Type.GetPropertiesGetType(String) metodo per ottenere una matrice di PropertyInfo oggetti che rappresentano le proprietà del tipo e quindi visualizza informazioni sulle proprietà astratte del tipo. Si noti che la chiamata al GetType(String) metodo usa il nome completo del tipo, ovvero lo spazio dei nomi insieme al nome del tipo.

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)

Commenti

Questo metodo esegue solo ricerche nell'istanza dell'assembly corrente. Il name parametro include lo spazio dei nomi ma non l'assembly. Per cercare altri assembly per un tipo, usare l'overload del metodo, che può facoltativamente includere un nome visualizzato dell'assembly Type.GetType(String) come parte del nome del tipo.

Nota

Se il tipo è stato inoltrato a un altro assembly, viene comunque restituito da questo metodo. Per informazioni sull'inoltro dei tipi, vedere Inoltro dei tipi in Common Language Runtime.

Si applica a

.NET 9 e altre versioni
Prodotto Versioni
.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 ();

Restituisce

Implementazioni

Si applica a

.NET Framework 1.1
Prodotto Versioni
.NET Framework 1.1