IMethodSymbol Interface
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento).
public interface class IMethodSymbol : IEquatable<Microsoft::CodeAnalysis::ISymbol ^>, Microsoft::CodeAnalysis::ISymbol
public interface IMethodSymbol : IEquatable<Microsoft.CodeAnalysis.ISymbol>, Microsoft.CodeAnalysis.ISymbol
type IMethodSymbol = interface
interface ISymbol
interface IEquatable<ISymbol>
Public Interface IMethodSymbol
Implements IEquatable(Of ISymbol), ISymbol
- Implementações
Comentários
Essa interface é reservada para implementação por suas APIs associadas. Reservamos o direito de mudá-lo no futuro.
Propriedades
Arity |
Retorna a aridade desse método ou o número de parâmetros de tipo necessários. Um método não genérico tem aridade zero. |
AssociatedAnonymousDelegate |
Se esse método for um método Lambda (MethodKind = MethodKind.LambdaMethod) e houver um delegado anônimo associado a ele, retornará esse delegado. Retorna nulo se o símbolo não for um lambda ou se ele não tiver um delegado anônimo associado a ele. |
AssociatedSymbol |
Retorna um símbolo (por exemplo, propriedade, evento etc.) associado ao método. |
CallingConvention |
A enumeração da convenção de chamada do símbolo do método. |
CanBeReferencedByName |
Retornará true se esse símbolo puder ser referenciado por seu nome no código. (Herdado de ISymbol) |
ConstructedFrom |
Retorna o símbolo do método do qual esse método foi construído. O símbolo do método resultante tem o mesmo tipo (se houver), mas tem argumentos de tipo que são os mesmos que os parâmetros de tipo (embora seu tipo de contenção não possa). |
ContainingAssembly |
Obtém o IAssemblySymbol assembly que contém. Retornará nulo se o símbolo for compartilhado em vários assemblies. (Herdado de ISymbol) |
ContainingModule |
Obtém o IModuleSymbol módulo que contém. Retornará nulo se o símbolo for compartilhado em vários módulos. (Herdado de ISymbol) |
ContainingNamespace |
Obtém o INamespaceSymbol namespace de cercamento mais próximo. Retornará nulo se o símbolo não estiver contido em um namespace. (Herdado de ISymbol) |
ContainingSymbol |
Obtém o ISymbol símbolo que contém imediatamente. (Herdado de ISymbol) |
ContainingType |
Obtém o INamedTypeSymbol tipo que contém. Retornará nulo se o símbolo não estiver contido em um tipo. (Herdado de ISymbol) |
DeclaredAccessibility |
Obtém uma Accessibility indicação da acessibilidade declarada para o símbolo. Retornará NotApplicable se nenhuma acessibilidade for declarada. (Herdado de ISymbol) |
DeclaringSyntaxReferences |
Obtenha os nós de sintaxe em que esse símbolo foi declarado na origem. Alguns símbolos (por exemplo, classes parciais) podem ser definidos em mais de um local. Essa propriedade deve retornar um ou mais nós de sintaxe somente se o símbolo foi declarado no código-fonte e também não foi declarado implicitamente (consulte a propriedade IsImplicitlyDeclared). Observe que, para o símbolo de namespace, a sintaxe de declaração pode estar declarando um namespace aninhado. Por exemplo, o nó de sintaxe de declaração para N1 no "namespace N1. N2 {...}" é toda a NamespaceDeclarationSyntax para N1. N2. Para o namespace global, a sintaxe de declaração será a CompilationUnitSyntax. (Herdado de ISymbol) |
ExplicitInterfaceImplementations |
Retorna métodos de interface explicitamente implementados por esse método. |
HasUnsupportedMetadata |
Indica que esse símbolo usa metadados que não podem ser suportados pelo idioma. Os exemplos incluem:
Isso é diferenciado de, por exemplo, referências a símbolos de metadados definidos em assemblies que não foram referenciados. Símbolos em que isso retorna true nunca podem ser usados com êxito e, portanto, nunca devem aparecer em nenhum recurso de IDE. Isso é definido para símbolos de metadados, da seguinte maneira:
|
HidesBaseMethodsByName |
Retornará true se esse método ocultar métodos base por nome. Isso não pode ser especificado diretamente na linguagem C#, mas pode ser verdadeiro para métodos definidos em outros idiomas importados de metadados. O equivalente ao sinalizador "hidebyname" nos metadados. |
IsAbstract |
Obtém um valor que indica se o símbolo é abstrato. (Herdado de ISymbol) |
IsAsync |
Retorna true se este método for um método assíncrono |
IsCheckedBuiltin |
Retorna se esse operador interno verifica se há estouro inteiro. |
IsConditional |
Retorna um sinalizador que indica se esse símbolo tem pelo menos um atributo condicional aplicado/herdado. |
IsDefinition |
Obtém um valor que indica se o símbolo é a definição original. Retornará false se o símbolo for derivado de outro símbolo, por substituição de tipo por instância. (Herdado de ISymbol) |
IsExtensionMethod |
Retorna true se esse método for um método de extensão. |
IsExtern |
Obtém um valor que indica se o símbolo é definido externamente. (Herdado de ISymbol) |
IsGenericMethod |
Retorna se esse método é genérico; Ou seja, ele tem algum parâmetro de tipo? |
IsImplicitlyDeclared |
Retorna true se esse símbolo foi criado automaticamente pelo compilador e não tem uma declaração de código-fonte correspondente explícita. (Herdado de ISymbol) |
IsInitOnly |
Retorna true para acessadores de conjunto 'init' e false caso contrário. |
IsOverride |
Obtém um valor que indica se o símbolo é uma substituição de um símbolo de classe base. (Herdado de ISymbol) |
IsPartialDefinition |
Retornar true se essa for uma definição de método parcial sem um corpo. Se houver um corpo em implementação, ele poderá ser recuperado com PartialImplementationPart. |
IsReadOnly |
Indica se o método é readonly, ou seja, se o parâmetro do receptor 'this' é 'ref readonly'. Retorna true para métodos e acessadores de instância readonly e para métodos de extensão reduzidos com um parâmetro "this in". |
IsSealed |
Obtém um valor que indica se o símbolo está lacrado. (Herdado de ISymbol) |
IsStatic |
Obtém um valor que indica se o símbolo é estático. (Herdado de ISymbol) |
IsVararg |
Retorna se esse método está usando a convenção de chamada VARARG da CLI. Isso é usado para listas de argumentos de variáveis no estilo C. Isso é usado extremamente raramente no código C# e é representado usando a palavra-chave "__arglist" não documentada. Observe que os métodos com "params" no último parâmetro são indicados com a propriedade "IsParams" em ParameterSymbol e não são representados com essa propriedade. |
IsVirtual |
Obtém um valor que indica se o símbolo é virtual. (Herdado de ISymbol) |
Kind |
Obtém o SymbolKind tipo de símbolo que indica. (Herdado de ISymbol) |
Language |
Obtém o idioma de origem ("C#" ou "Visual Basic"). (Herdado de ISymbol) |
Locations |
Obtém os locais em que o símbolo foi originalmente definido, seja na origem ou nos metadados. Alguns símbolos (por exemplo, classes parciais) podem ser definidos em mais de um local. (Herdado de ISymbol) |
MetadataName |
Obtém o nome de um símbolo como ele aparece nos metadados. Na maioria das vezes, isso é o mesmo que a propriedade Name, com as seguintes exceções:
|
MetadataToken |
Obtém o token de metadados associado a esse símbolo ou 0 se o símbolo não for carregado de metadados. (Herdado de ISymbol) |
MethodImplementationFlags |
Retorna os sinalizadores de implementação para o símbolo de método fornecido. |
MethodKind |
Obtém o tipo de método que é esse. Há vários tipos diferentes de coisas na linguagem C# que são representadas como métodos. Essa propriedade permite distinguir essas coisas sem precisar decodificar o nome do método. |
Name |
Obtém o nome do símbolo. Retorna a cadeia de caracteres vazia se não for nomeada. (Herdado de ISymbol) |
OriginalDefinition |
Obtenha a definição original desse símbolo. Se esse símbolo for derivado de outro símbolo por substituição de tipo (digamos), ele obterá o símbolo original, pois ele foi definido na origem ou nos metadados. |
OverriddenMethod |
Se esse método substituir outro método (porque ambos tinham o modificador de substituição e havia corretamente um método para substituir), retorna o método substituído. |
Parameters |
Obtém os parâmetros deste método. Se esse método não tiver parâmetros, retornará uma lista vazia. |
PartialDefinitionPart |
Se essa for uma parte de implementação de método parcial, retornará a parte de definição correspondente. Caso contrário, nulo. |
PartialImplementationPart |
Se essa for uma declaração de método parcial sem um corpo e o método for implementado com um corpo, retornará essa definição. Caso contrário, nulo. |
ReceiverNullableAnnotation |
Se esse método puder ser aplicado a um objeto, retornará a nulidade de nível superior do objeto ao qual ele é aplicado. |
ReceiverType |
Se esse método puder ser aplicado a um objeto, retornará o tipo de objeto ao qual ele é aplicado. |
ReducedFrom |
Se esse método for um método de extensão reduzido, retornará a definição do método de extensão do qual isso foi reduzido. Caso contrário, retornará nulo. |
RefCustomModifiers |
Modificadores personalizados associados ao modificador de ref ou a uma matriz vazia se não houver nenhum. |
RefKind |
Retorna o RefKind do método. |
ReturnNullableAnnotation |
Obtém a nulidade de nível superior do tipo de retorno do método. |
ReturnsByRef |
Retornará true se esse método retornar por referência. |
ReturnsByRefReadonly |
Retornará true se esse método retornar por ref readonly. |
ReturnsVoid |
Retornará true se este método não tiver nenhum tipo de retorno; Ou seja, retorna "void". |
ReturnType |
Obtém o tipo retornado do método. |
ReturnTypeCustomModifiers |
Retorna a lista de modificadores personalizados, se houver, associados ao tipo de retorno. |
TypeArgumentNullableAnnotations |
Retorna a nulidade de nível superior dos argumentos de tipo que foram substituídos pelos parâmetros de tipo. Se nada tiver sido substituído por um determinado parâmetro de tipo, será None retornado. |
TypeArguments |
Retorna os argumentos de tipo que foram substituídos pelos parâmetros de tipo. Se nada tiver sido substituído por um determinado parâmetro de tipo, o parâmetro de tipo em si será considerado o argumento de tipo. |
TypeArgumentsNullableAnnotations |
Retorna a nulidade de nível superior dos argumentos de tipo que foram substituídos pelos parâmetros de tipo. Se nada tiver sido substituído por um determinado parâmetro de tipo, será NotApplicable retornado. |
TypeParameters |
Obtenha os parâmetros de tipo neste método. Se o método não tiver genérico, retornará uma lista vazia. |
UnmanagedCallingConventionTypes |
Tipos de modificador que são considerados parte da convenção de chamada desse método, se o MethodKind é FunctionPointerSignature e o CallingConvention é Unmanaged. Se essa não for uma assinatura de ponteiro de função ou a convenção de chamada não for gerenciada, essa será uma matriz vazia. A ordem e a duplicação desses modificadores refletem a ordem de origem/metadados e a duplicação, o que quer que esse símbolo veio. |
Métodos
Accept(SymbolVisitor) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). (Herdado de ISymbol) |
Accept<TArgument,TResult>(SymbolVisitor<TArgument,TResult>, TArgument) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). (Herdado de ISymbol) |
Accept<TResult>(SymbolVisitor<TResult>) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). (Herdado de ISymbol) |
Construct(ImmutableArray<ITypeSymbol>, ImmutableArray<NullableAnnotation>) |
Retorna um método construído, considerando seus argumentos de tipo e anotações anuláveis de argumento de tipo. |
Construct(ITypeSymbol[]) |
Retorna um método construído considerando seus argumentos de tipo. |
Equals(ISymbol, SymbolEqualityComparer) |
Determina se esse símbolo é igual a outro, de acordo com as regras do fornecido SymbolEqualityComparer (Herdado de ISymbol) |
GetAttributes() |
Obtém os atributos do símbolo. Retorna um vazio IEnumerable<T> se não houver atributos. (Herdado de ISymbol) |
GetDllImportData() |
Informações de invocação de plataforma ou nulas se o método não for um P/Invoke. |
GetDocumentationCommentId() |
Retorna a ID de Comentário da Documentação do símbolo ou nula se o símbolo não oferecer suporte a comentários de documentação. (Herdado de ISymbol) |
GetDocumentationCommentXml(CultureInfo, Boolean, CancellationToken) |
Obtém o XML (como texto) para o comentário associado ao símbolo. (Herdado de ISymbol) |
GetReturnTypeAttributes() |
Retorna a lista de atributos personalizados, se houver, associados ao valor retornado. |
GetTypeInferredDuringReduction(ITypeParameterSymbol) |
Se esse método for um método de extensão reduzido, retornará um tipo inferido durante o processo de redução para o parâmetro de tipo. |
ReduceExtensionMethod(ITypeSymbol) |
Se esse for um método de extensão que pode ser aplicado a um receptor do tipo fornecido, retornará um símbolo de método de extensão reduzido, portanto formado. Caso contrário, retornará nulo. |
ToDisplayParts(SymbolDisplayFormat) |
Converta um símbolo em uma matriz de partes de cadeia de caracteres, cada uma delas com um tipo. Útil para colorir a cadeia de caracteres de exibição. (Herdado de ISymbol) |
ToDisplayString(SymbolDisplayFormat) |
Converte o símbolo em uma representação de cadeia de caracteres. (Herdado de ISymbol) |
ToMinimalDisplayParts(SemanticModel, Int32, SymbolDisplayFormat) |
Converta um símbolo em uma matriz de partes de cadeia de caracteres, cada uma delas com um tipo. Pode ser adaptado para um local específico no código-fonte. Útil para colorir a cadeia de caracteres de exibição. (Herdado de ISymbol) |
ToMinimalDisplayString(SemanticModel, Int32, SymbolDisplayFormat) |
Converta um símbolo em uma cadeia de caracteres que pode ser exibida para o usuário. Pode ser adaptado para um local específico no código-fonte. (Herdado de ISymbol) |
Métodos de Extensão
GetConstructedReducedFrom(IMethodSymbol) |
Retorna a forma construída da propriedade ReducedFrom, incluindo os argumentos de tipo que foram inferidos durante a redução ou fornecidos no site de chamada. |
HandledEvents(IMethodSymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsMustOverride(ISymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsNotOverridable(ISymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsOverloads(IMethodSymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsOverridable(ISymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsOverrides(ISymbol) |
Representa um método ou símbolo semelhante a um método (incluindo construtor, destruidor, operador ou acessador de propriedade/evento). |
IsShared(ISymbol) |
Determina se o símbolo é Compartilhado. |