ITypeSymbol Интерфейс
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Представляет тип.
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
- Производный
- Реализации
Комментарии
Этот интерфейс зарезервирован для реализации связанными с ним API. Мы оставляем за собой право изменить его в будущем.
Свойства
AllInterfaces |
Список всех интерфейсов, для которых этот тип является объявленным подтипом, за исключением самого этого типа. Сюда входят все объявленные базовые интерфейсы, все объявленные базовые интерфейсы базовых типов и все объявленные базовые интерфейсы этих результатов (рекурсивно). Это также эффективный набор интерфейсов параметра типа. Каждый результат отображается в списке ровно один раз. Этот список топологически отсортирован по связи наследования: если тип интерфейса A расширяет тип интерфейса B, то A предшествует B в списке. Это не совсем то же самое, что "все интерфейсы, для которых этот тип является правильным подтипом", поскольку он не учитывает дисперсию: AllInterfaces для строки IEnumerable<не будет включать объект> IEnumerable<.> |
BaseType |
Объявленный базовый тип этого типа или null. Тип объекта, типы интерфейсов и типы указателей не имеют базового типа. Базовым типом параметра типа является его действующий базовый класс. |
CanBeReferencedByName |
Возвращает значение true, если на этот символ можно ссылаться по его имени в коде. (Унаследовано от ISymbol) |
ContainingAssembly |
IAssemblySymbol Возвращает для содержащей сборки. Возвращает значение NULL, если символ является общим для нескольких сборок. (Унаследовано от ISymbol) |
ContainingModule |
IModuleSymbol Возвращает для содержащего модуля. Возвращает значение NULL, если символ является общим для нескольких модулей. (Унаследовано от ISymbol) |
ContainingNamespace |
Возвращает для INamespaceSymbol ближайшего включающего пространства имен. Возвращает значение NULL, если символ не содержится в пространстве имен. (Унаследовано от ISymbol) |
ContainingSymbol |
ISymbol Возвращает объект для непосредственно содержащего символа. (Унаследовано от ISymbol) |
ContainingType |
INamedTypeSymbol Возвращает для содержащегося типа. Возвращает значение NULL, если символ не содержится в типе. (Унаследовано от ISymbol) |
DeclaredAccessibility |
Возвращает объект , указывающий Accessibility объявленную доступность для символа. Возвращает значение NotApplicable, если специальные возможности не объявлены. (Унаследовано от ISymbol) |
DeclaringSyntaxReferences |
Получите синтаксические узлы, на которых этот символ был объявлен в источнике. Некоторые символы (например, разделяемые классы) могут быть определены в нескольких расположениях. Это свойство должно возвращать один или несколько синтаксических узлов, только если символ был объявлен в исходном коде, а также не был неявно объявлен (см. свойство IsImplicitlyDeclared). Обратите внимание, что для символа пространства имен синтаксис объявления может объявлять вложенное пространство имен. Например, объявляющий узел синтаксиса для N1 в пространстве имен N1. N2 {...}" — это все пространство именDeclarationSyntax для N1. N2. Для глобального пространства имен декларативным синтаксисом будет CompilationUnitSyntax. (Унаследовано от ISymbol) |
HasUnsupportedMetadata |
Указывает, что этот символ использует метаданные, которые не поддерживаются языком. Примеры приведены ниже.
Это отличается, например, от ссылок на символы метаданных, определенные в сборках, на которые не ссылались. Символы, в которых возвращается значение true, никогда не могут использоваться успешно и поэтому никогда не должны отображаться в какой-либо функции интегрированной среды разработки. Этот параметр задается для символов метаданных следующим образом:
|
Interfaces |
Возвращает набор интерфейсов, непосредственно реализуемых этим типом. Этот набор не включает интерфейсы, которые являются базовыми интерфейсами непосредственно реализованных интерфейсов. Сюда входят интерфейсы, объявленные в качестве ограничений для параметров типа. |
IsAbstract |
Возвращает значение, указывающее, является ли символ абстрактным. (Унаследовано от ISymbol) |
IsAnonymousType |
Является ли это символом для анонимного типа (включая анонимный делегат VB). |
IsDefinition |
Возвращает значение, указывающее, является ли символ исходным определением. Возвращает значение false, если символ является производным от другого символа путем подстановки типа для экземпляра . (Унаследовано от ISymbol) |
IsExtern |
Возвращает значение, указывающее, определен ли символ извне. (Унаследовано от ISymbol) |
IsImplicitlyDeclared |
Возвращает значение true, если этот символ был автоматически создан компилятором и не имеет явного соответствующего объявления исходного кода. (Унаследовано от ISymbol) |
IsNamespace |
Возвращает значение true, если этот символ является пространством имен. Если это не пространство имен, это должен быть тип. (Унаследовано от INamespaceOrTypeSymbol) |
IsNativeIntegerType |
Значение true, если тип представляет собственное целое число. В C# типы, представленные ключевыми словами языка nint и nuint. |
IsOverride |
Возвращает значение, указывающее, является ли символ переопределением символа базового класса. (Унаследовано от ISymbol) |
IsReadOnly |
Значение true, если тип доступен только для чтения. |
IsRecord |
Для исходных символов значение true, если тип является записью. Для символов метаданных значение true, если тип является записью и ссылочным типом. |
IsReferenceType |
Значение true, если этот тип известен как ссылочный тип. Это никогда не так, что IsReferenceType и оба IsValueType возвращают значение true. Однако для параметра IsReferenceType неограниченного типа и IsValueType будут возвращать значение false. |
IsRefLikeType |
Значение true, если тип похож на ссылку, то есть он следует правилам, аналогичным переменным clR by-ref. False, если тип не является ссылочный или язык не имеет понятия ссылочных типов. |
IsSealed |
Возвращает значение, указывающее, запечатан ли символ. (Унаследовано от ISymbol) |
IsStatic |
Возвращает значение, указывающее, является ли символ статическим. (Унаследовано от ISymbol) |
IsTupleType |
Является ли это символом кортежа . |
IsType |
Возвращает значение true, если эти символы являются типом. Если это не тип, это должно быть пространство имен. (Унаследовано от INamespaceOrTypeSymbol) |
IsUnmanagedType |
Значение true, если тип неуправляем в соответствии с языковыми правилами. False, если управляемая или если язык не имеет понятия неуправляемых типов. |
IsValueType |
Значение true, если этот тип известен как тип значения. Это никогда не так, что IsReferenceType и оба IsValueType возвращают значение true. Однако для параметра IsReferenceType неограниченного типа и IsValueType будут возвращать значение false. |
IsVirtual |
Возвращает значение, указывающее, является ли символ виртуальным. (Унаследовано от ISymbol) |
Kind |
Возвращает объект , указывающий SymbolKind , какой тип символа. (Унаследовано от ISymbol) |
Language |
Возвращает исходный язык ("C#" или "Visual Basic"). (Унаследовано от ISymbol) |
Locations |
Возвращает расположения, в которых символ был первоначально определен в источнике или метаданных. Некоторые символы (например, разделяемые классы) могут быть определены в нескольких расположениях. (Унаследовано от ISymbol) |
MetadataName |
Возвращает имя символа, отображаемого в метаданных. В большинстве случаев это то же самое, что и свойство Name, за следующими исключениями:
|
MetadataToken |
Возвращает маркер метаданных, связанный с этим символом, или значение 0, если символ не загружается из метаданных. (Унаследовано от ISymbol) |
Name |
Получает имя символа. Возвращает пустую строку, если она не именована. (Унаследовано от ISymbol) |
NullableAnnotation |
Заметка, допускаемая значение NULL, связанная с типом, или None , если ее нет. |
OriginalDefinition |
Исходное определение этого символа. Если этот символ создан из другого символа путем подстановки типа, то OriginalDefinition получает исходный символ, определенный в источнике или метаданных. |
SpecialType |
Перечисляемое значение, идентифицирующее определенные "специальные" типы, такие как Object. Возвращает значение None , если тип не является специальным. |
TypeKind |
Перечислимое значение, определяющее, является ли этот тип массивом, указателем, перечислением и т. д. |
Методы
Accept(SymbolVisitor) |
Представляет тип. (Унаследовано от ISymbol) |
Accept<TArgument,TResult>(SymbolVisitor<TArgument,TResult>, TArgument) |
Представляет тип. (Унаследовано от ISymbol) |
Accept<TResult>(SymbolVisitor<TResult>) |
Представляет тип. (Унаследовано от ISymbol) |
Equals(ISymbol, SymbolEqualityComparer) |
Определяет, равен ли этот символ другому в соответствии с правилами предоставленного SymbolEqualityComparer (Унаследовано от ISymbol) |
FindImplementationForInterfaceMember(ISymbol) |
Возвращает соответствующий символ в этом типе или базовом типе, реализующий interfaceMember (неявно или явно), или null, если такого символа не существует (это может быть вызвано тем, что этот тип не реализует контейнер interfaceMember или этот тип не предоставляет член, который успешно реализует interfaceMember). |
GetAttributes() |
Возвращает атрибуты для символа. Возвращает пустое IEnumerable<T> значение, если атрибуты отсутствуют. (Унаследовано от ISymbol) |
GetDocumentationCommentId() |
Возвращает идентификатор комментария документации для символа или значение NULL, если символ не поддерживает комментарии к документации. (Унаследовано от ISymbol) |
GetDocumentationCommentXml(CultureInfo, Boolean, CancellationToken) |
Возвращает XML-код (в виде текста) для комментария, связанного с символом . (Унаследовано от ISymbol) |
GetMembers() |
Получение всех элементов этого символа. (Унаследовано от INamespaceOrTypeSymbol) |
GetMembers(String) |
Получение всех элементов этого символа с определенным именем. (Унаследовано от INamespaceOrTypeSymbol) |
GetTypeMembers() |
Получает все члены этого символа, которые являются типами. (Унаследовано от INamespaceOrTypeSymbol) |
GetTypeMembers(String) |
Получает все члены этого символа, которые являются типами с определенным именем любого arity. (Унаследовано от INamespaceOrTypeSymbol) |
GetTypeMembers(String, Int32) |
Получение всех элементов этого символа, которые являются типами, имеющими определенное имя и arity (Унаследовано от INamespaceOrTypeSymbol) |
ToDisplayParts(NullableFlowState, SymbolDisplayFormat) |
Преобразует символ в массив строковых частей, каждая из которых имеет тип. Используется для раскраски отображаемой строки. |
ToDisplayParts(SymbolDisplayFormat) |
Преобразуйте символ в массив строковых частей, каждая из которых имеет тип . Полезно для раскраски отображаемой строки. (Унаследовано от ISymbol) |
ToDisplayString(NullableFlowState, SymbolDisplayFormat) |
Преобразует |
ToDisplayString(SymbolDisplayFormat) |
Преобразует символ в строковое представление. (Унаследовано от ISymbol) |
ToMinimalDisplayParts(SemanticModel, Int32, SymbolDisplayFormat) |
Преобразуйте символ в массив строковых частей, каждая из которых имеет тип . Может быть адаптировано к определенному расположению в исходном коде. Полезно для раскраски отображаемой строки. (Унаследовано от ISymbol) |
ToMinimalDisplayParts(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat) |
Преобразуйте символ в массив строковых частей, каждая из которых имеет тип. Может быть адаптировано к определенному расположению в исходном коде. Используется для раскраски отображаемой строки. |
ToMinimalDisplayString(SemanticModel, Int32, SymbolDisplayFormat) |
Преобразуйте символ в строку, которая может отображаться для пользователя. Может быть адаптировано к определенному расположению в исходном коде. (Унаследовано от ISymbol) |
ToMinimalDisplayString(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat) |
Преобразует символ в строку, которая может отображаться пользователю. Может быть адаптировано к определенному расположению в исходном коде. |
WithNullableAnnotation(NullableAnnotation) |
Возвращает тот же тип, что и этот тип, но с заданной заметкой, допускаемой значением NULL. |
Методы расширения
IsMustOverride(ISymbol) |
Представляет тип. |
IsNotOverridable(ISymbol) |
Представляет тип. |
IsOverridable(ISymbol) |
Представляет тип. |
IsOverrides(ISymbol) |
Представляет тип. |
IsShared(ISymbol) |
Определяет, является ли символ общим. |