Compartir a través de


ITypeSymbol Interfaz

Definición

Representa un tipo.

public interface class ITypeSymbol : IEquatable<Microsoft::CodeAnalysis::ISymbol ^>, Microsoft::CodeAnalysis::INamespaceOrTypeSymbol
public interface ITypeSymbol : IEquatable<Microsoft.CodeAnalysis.ISymbol>, Microsoft.CodeAnalysis.INamespaceOrTypeSymbol
type ITypeSymbol = interface
    interface INamespaceOrTypeSymbol
    interface ISymbol
    interface IEquatable<ISymbol>
Public Interface ITypeSymbol
Implements IEquatable(Of ISymbol), INamespaceOrTypeSymbol
Derivado
Implementaciones

Comentarios

Esta interfaz está reservada para la implementación por sus API asociadas. Nos reservamos el derecho de cambiarlo en el futuro.

Propiedades

Nombre Description
AllInterfaces

La lista de todas las interfaces de las que este tipo es un subtipo declarado, excepto este tipo. Esto incluye todas las interfaces base declaradas, todas las interfaces base declaradas de tipos base y todas las interfaces base declaradas de esos resultados (recursivamente). Esto también es el conjunto de interfaz eficaz de un parámetro de tipo. Cada resultado aparece exactamente una vez en la lista. Esta lista se ordena de forma topológica por la relación de herencia: si el tipo de interfaz A extiende el tipo de interfaz B, A precede a B en la lista. Esto no es igual que "todas las interfaces de las que este tipo es un subtipo adecuado" porque no tiene en cuenta la varianza: AllInterfaces para la cadena IEnumerable<no incluirá el objeto> IEnumerable<.>

BaseType

Tipo base declarado de este tipo o null. El tipo de objeto, los tipos de interfaz, los tipos de puntero y los parámetros de tipo no tienen un tipo base.

CanBeReferencedByName

Devuelve true si se puede hacer referencia a este símbolo por su nombre en el código.

(Heredado de ISymbol)
ContainingAssembly

Obtiene para IAssemblySymbol el ensamblado contenedor. Devuelve null si el símbolo se comparte entre varios ensamblados.

(Heredado de ISymbol)
ContainingModule

Obtiene para IModuleSymbol el módulo contenedor. Devuelve null si el símbolo se comparte entre varios módulos.

(Heredado de ISymbol)
ContainingNamespace

Obtiene para INamespaceSymbol el espacio de nombres más cercano. Devuelve null si el símbolo no está contenido en un espacio de nombres.

(Heredado de ISymbol)
ContainingSymbol

Obtiene para ISymbol el símbolo que contiene inmediatamente.

(Heredado de ISymbol)
ContainingType

Obtiene para INamedTypeSymbol el tipo contenedor. Devuelve null si el símbolo no está contenido dentro de un tipo.

(Heredado de ISymbol)
DeclaredAccessibility

Obtiene un que Accessibility indica la accesibilidad declarada para el símbolo. Devuelve NotApplicable si no se declara ninguna accesibilidad.

(Heredado de ISymbol)
DeclaringSyntaxReferences

Obtenga los nodos de sintaxis donde se declaró este símbolo en el origen. Algunos símbolos (por ejemplo, tipos parciales, como clases, estructuras e interfaces) se pueden definir en más de una ubicación. Esta propiedad solo debe devolver uno o más nodos de sintaxis si el símbolo se declaró en el código fuente y tampoco se declaró implícitamente (vea la propiedad IsImplicitlyDeclared).

Tenga en cuenta que para los miembros parciales (métodos, propiedades, eventos), esta propiedad devuelve solo un nodo de sintaxis. Para obtener todos los nodos de sintaxis de un miembro parcial, use las PartialDefinitionPart propiedades y PartialImplementationPart en IMethodSymbol, IPropertySymbolo IEventSymbol.

Tenga en cuenta que para el símbolo del espacio de nombres, la sintaxis declarante podría declarar un espacio de nombres anidado. Por ejemplo, el nodo de sintaxis declarante para N1 en "espacio de nombres N1. N2 {...}" es el espacio de nombres completoDeclarationSyntax para N1. N2. Para el espacio de nombres global, la sintaxis declarante será CompilationUnitSyntax.

(Heredado de ISymbol)
ExtensionParameter
Obsoletos.

Parámetro de extensión si se trata de una declaración de extensión (IsExtension es true).

HasUnsupportedMetadata

Indica que este símbolo usa metadatos que no pueden ser compatibles con el idioma.

Algunos ejemplos son:

  • Tipos de puntero en VB
  • Tipo de valor devuelto ByRef
  • Modificadores personalizados necesarios

Esto se distingue de, por ejemplo, referencias a símbolos de metadatos definidos en ensamblados a los que no se hacía referencia. Los símbolos en los que devuelve true nunca se pueden usar correctamente y, por tanto, nunca deben aparecer en ninguna característica del IDE.

Esto se establece para símbolos de metadatos, como se indica a continuación:

  • Tipo: si un tipo no es compatible (por ejemplo, un tipo de puntero)
  • Método: el parámetro o el tipo de valor devuelto no son compatibles
  • Campo: el tipo no es compatible
  • Evento: el tipo no es compatible
  • Propiedad: el tipo no es compatible
  • Parámetro: el tipo no es compatible

(Heredado de ISymbol)
Interfaces

Obtiene el conjunto de interfaces que este tipo implementa directamente. Este conjunto no incluye interfaces que son interfaces base de interfaces implementadas directamente. Esto incluye las interfaces declaradas como restricciones en los parámetros de tipo.

IsAbstract

Obtiene un valor que indica si el símbolo es abstracto.

(Heredado de ISymbol)
IsAnonymousType

Es este un símbolo para un tipo anónimo (incluido el delegado de VB anónimo).

IsDefinition

Obtiene un valor que indica si el símbolo es la definición original. Devuelve false si el símbolo se deriva de otro símbolo, por sustitución de tipos por ejemplo.

(Heredado de ISymbol)
IsExtension
Obsoletos.

Es este un símbolo para una declaración de extensión.

IsExtern

Obtiene un valor que indica si el símbolo se define externamente.

(Heredado de ISymbol)
IsImplicitlyDeclared

Devuelve true si el compilador creó automáticamente este símbolo y no tiene una declaración de código fuente correspondiente explícita.

(Heredado de ISymbol)
IsNamespace

Devuelve true si este símbolo es un espacio de nombres. Si no es un espacio de nombres, debe ser un tipo.

(Heredado de INamespaceOrTypeSymbol)
IsNativeIntegerType

True si el tipo representa un entero nativo. En C#, los tipos representados por palabras clave de lenguaje 'nint' y 'nuint'.

IsOverride

Obtiene un valor que indica si el símbolo es una invalidación de un símbolo de clase base.

(Heredado de ISymbol)
IsReadOnly

True si el tipo es de solo lectura.

IsRecord

Para los símbolos de origen, true si el tipo es un registro. Para los símbolos de metadatos, true si el tipo es un registro y un tipo de referencia.

IsReferenceType

True si se sabe que este tipo es un tipo de referencia. Nunca es el caso de que IsReferenceType y IsValueType ambos devuelvan true. Sin embargo, para un parámetro IsReferenceType de tipo sin restricciones y IsValueType ambos devolverán false.

IsRefLikeType

True si el tipo es de tipo ref, lo que significa que sigue las reglas similares a las variables CLR by-ref. False si el tipo no es de tipo ref o si el lenguaje no tiene ningún concepto de tipos de tipo ref.

IsSealed

Obtiene un valor que indica si el símbolo está sellado.

(Heredado de ISymbol)
IsStatic

Obtiene un valor que indica si el símbolo es estático.

(Heredado de ISymbol)
IsTupleType

Es este un símbolo para una tupla .

IsType

Devuelve true si este símbolo es un tipo. Si no es un tipo, debe ser un espacio de nombres.

(Heredado de INamespaceOrTypeSymbol)
IsUnmanagedType

True si el tipo no está administrado según las reglas de idioma. False si se administra o si el lenguaje no tiene ningún concepto de tipos no administrados.

IsValueType

True si se sabe que este tipo es un tipo de valor. Nunca es el caso de que IsReferenceType y IsValueType ambos devuelvan true. Sin embargo, para un parámetro IsReferenceType de tipo sin restricciones y IsValueType ambos devolverán false.

IsVirtual

Obtiene un valor que indica si el símbolo es virtual.

(Heredado de ISymbol)
Kind

Obtiene el que SymbolKind indica qué tipo de símbolo es.

(Heredado de ISymbol)
Language

Obtiene el lenguaje de origen ("C#" o "Visual Basic").

(Heredado de ISymbol)
Locations

Obtiene las ubicaciones donde se definió originalmente el símbolo, ya sea en origen o metadatos. Algunos símbolos (por ejemplo, tipos parciales, como clases, estructuras e interfaces) se pueden definir en más de una ubicación. Tenga en cuenta que para los miembros parciales (como métodos, propiedades y eventos), esta propiedad devuelve solo una ubicación. Para obtener todas las ubicaciones de un miembro parcial, use las PartialDefinitionPart propiedades y PartialImplementationPart en IMethodSymbol, IPropertySymbolo IEventSymbol.

(Heredado de ISymbol)
MetadataName

Obtiene el nombre de un símbolo tal como aparece en los metadatos. La mayoría de las veces, esto es lo mismo que la propiedad Name, con las siguientes excepciones:

  1. El nombre de metadatos de tipos genéricos incluye el sufijo "'1", "'2", etc. que indica el número de parámetros de tipo (no incluye, sin embargo, nombres de tipos o espacios de nombres que contienen).
  2. El nombre de metadatos de los nombres de interfaz explícitos ha quitado espacios, en comparación con la propiedad name.
  3. La longitud de los nombres se limita a no superar las restricciones de metadatos.
(Heredado de ISymbol)
MetadataToken

Obtiene el token de metadatos asociado a este símbolo o 0 si el símbolo no se carga desde metadatos.

(Heredado de ISymbol)
Name

Obtiene el nombre del símbolo. Devuelve la cadena vacía si no tiene nombre.

(Heredado de ISymbol)
NullableAnnotation

Anotación que acepta valores NULL asociada al tipo o None si no hay ninguna.

OriginalDefinition

Definición original de este símbolo. Si este símbolo se construye a partir de otro símbolo por sustitución de tipos, OriginalDefinition obtiene el símbolo original tal como se definió en el origen o los metadatos.

SpecialType

Valor enumerado que identifica determinados tipos "especiales", como Object. Devuelve None si el tipo no es especial.

TypeKind

Valor enumerado que identifica si este tipo es una matriz, puntero, enumeración, etc.

Métodos

Nombre Description
Accept(SymbolVisitor)

Representa un tipo.

(Heredado de ISymbol)
Accept<TArgument,TResult>(SymbolVisitor<TArgument,TResult>, TArgument)

Representa un tipo.

(Heredado de ISymbol)
Accept<TResult>(SymbolVisitor<TResult>)

Representa un tipo.

(Heredado de ISymbol)
Equals(ISymbol, SymbolEqualityComparer)

Determina si este símbolo es igual a otro, según las reglas del proporcionado. SymbolEqualityComparer

(Heredado de ISymbol)
FindImplementationForInterfaceMember(ISymbol)

Devuelve el símbolo correspondiente en este tipo o un tipo base que implementa interfaceMember (ya sea implícita o explícitamente) o null si no existe ningún símbolo de este tipo (que puede ser porque este tipo no implementa el contenedor de interfaceMember o este tipo no proporciona un miembro que implemente interfaceMember correctamente).

GetAttributes()

Obtiene los atributos del símbolo. Devuelve un valor vacío ImmutableArray<T> si no hay ningún atributo.

(Heredado de ISymbol)
GetDocumentationCommentId()

Devuelve el id. de comentario de documentación del símbolo o null si el símbolo no admite comentarios de documentación.

(Heredado de ISymbol)
GetDocumentationCommentXml(CultureInfo, Boolean, CancellationToken)

Obtiene el XML (como texto) del comentario asociado al símbolo.

(Heredado de ISymbol)
GetMembers()

Obtiene todos los miembros de este símbolo.

(Heredado de INamespaceOrTypeSymbol)
GetMembers(String)

Obtiene todos los miembros de este símbolo que tienen un nombre determinado.

(Heredado de INamespaceOrTypeSymbol)
GetTypeMembers()

Obtenga todos los miembros de este símbolo que son tipos.

(Heredado de INamespaceOrTypeSymbol)
GetTypeMembers(String, Int32)

Obtener todos los miembros de este símbolo que son tipos que tienen un nombre y aridad determinados

(Heredado de INamespaceOrTypeSymbol)
GetTypeMembers(String)

Obtiene todos los miembros de este símbolo que son tipos que tienen un nombre determinado, de cualquier aridad.

(Heredado de INamespaceOrTypeSymbol)
ToDisplayParts(NullableFlowState, SymbolDisplayFormat)

Convierte un símbolo en una matriz de elementos de cadena, cada uno de los cuales tiene un tipo . Resulta útil para colorear la cadena de presentación.

ToDisplayParts(SymbolDisplayFormat)

Convierta un símbolo en una matriz de elementos de cadena, cada uno de los cuales tiene un tipo. Resulta útil para colorear la cadena de presentación.

(Heredado de ISymbol)
ToDisplayString(NullableFlowState, SymbolDisplayFormat)

Convierte un ITypeSymbol estado de flujo que acepta valores NULL en una representación de cadena.

ToDisplayString(SymbolDisplayFormat)

Convierte el símbolo en una representación de cadena.

(Heredado de ISymbol)
ToMinimalDisplayParts(SemanticModel, Int32, SymbolDisplayFormat)

Convierta un símbolo en una matriz de elementos de cadena, cada uno de los cuales tiene un tipo. Puede adaptarse a una ubicación específica en el código fuente. Resulta útil para colorear la cadena de presentación.

(Heredado de ISymbol)
ToMinimalDisplayParts(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat)

Convierta un símbolo en una matriz de elementos de cadena, cada uno de los cuales tiene un tipo. Puede adaptarse a una ubicación específica en el código fuente. Resulta útil para colorear la cadena de presentación.

ToMinimalDisplayString(SemanticModel, Int32, SymbolDisplayFormat)

Convierta un símbolo en una cadena que se pueda mostrar al usuario. Puede adaptarse a una ubicación específica en el código fuente.

(Heredado de ISymbol)
ToMinimalDisplayString(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat)

Convierte un símbolo en una cadena que se puede mostrar al usuario. Puede adaptarse a una ubicación específica en el código fuente.

WithNullableAnnotation(NullableAnnotation)

Devuelve el mismo tipo que este tipo, pero con la anotación que acepta valores NULL especificada.

Métodos de extensión

Nombre Description
IsMustOverride(ISymbol)

Representa un tipo.

IsNotOverridable(ISymbol)

Representa un tipo.

IsOverridable(ISymbol)

Representa un tipo.

IsOverrides(ISymbol)

Representa un tipo.

IsShared(ISymbol)

Determina si el símbolo es Compartido.

Se aplica a