Поделиться через


INamedTypeSymbol Интерфейс

Определение

Представляет тип, отличный от массива, указателя и параметра типа.

public interface class INamedTypeSymbol : IEquatable<Microsoft::CodeAnalysis::ISymbol ^>, Microsoft::CodeAnalysis::ITypeSymbol
public interface INamedTypeSymbol : IEquatable<Microsoft.CodeAnalysis.ISymbol>, Microsoft.CodeAnalysis.ITypeSymbol
type INamedTypeSymbol = interface
    interface ITypeSymbol
    interface INamespaceOrTypeSymbol
    interface ISymbol
    interface IEquatable<ISymbol>
Public Interface INamedTypeSymbol
Implements IEquatable(Of ISymbol), ITypeSymbol
Производный
Реализации

Комментарии

Этот интерфейс зарезервирован для реализации связанными API. Мы оставляем за собой право изменить его в будущем.

Свойства

AllInterfaces

Список всех интерфейсов, для которых этот тип является объявленным подтипом, за исключением самого этого типа. Сюда входят все объявленные базовые интерфейсы, все объявленные базовые интерфейсы базовых типов и все объявленные базовые интерфейсы этих результатов (рекурсивно). Это также эффективный набор интерфейсов параметра типа. Каждый результат отображается в списке ровно один раз. Этот список топологически отсортирован по связи наследования: если тип интерфейса A расширяет тип интерфейса B, то A предшествует B в списке. Это не совсем то же самое, что "все интерфейсы, для которых этот тип является правильным подтипом", поскольку он не учитывает дисперсию: AllInterfaces для строки IEnumerable<не будет включать объект> IEnumerable<.>

(Унаследовано от ITypeSymbol)
Arity

Возвращает arity этого типа или количество параметров типа, которые он принимает. Неуниверсивный тип имеет нулевую arity.

AssociatedSymbol

Для неявно объявленных типов делегатов возвращает значение EventSymbol, вызвавшее создание этого типа делегата. Для всех остальных типов возвращает значение NULL. Обратите внимание, что набор возможных связанных символов может быть расширен в будущем, чтобы отразить изменения в языках.

BaseType

Объявленный базовый тип этого типа или null. Тип объекта, типы интерфейсов и типы указателей не имеют базового типа. Базовым типом параметра типа является его действующий базовый класс.

(Унаследовано от ITypeSymbol)
CanBeReferencedByName

Возвращает значение true, если на этот символ можно ссылаться по его имени в коде.

(Унаследовано от ISymbol)
ConstructedFrom

Возвращает символ типа, из который был создан этот тип. Этот символ типа имеет тот же содержащий тип (если таковой имеется), но имеет аргументы типа, которые совпадают с параметрами типа (хотя его содержащий тип может не совпадать).

Constructors

Получение как экземплярных, так и статических конструкторов для этого типа.

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

Для типов делегатов возвращает метод invoke делегата. Возвращает значение NULL для всех других типов типов. Обратите внимание, что из метаданных можно импортировать неправильный тип делегата, который не имеет метода Invoke. Такой тип будет классифицирован как делегат, но его DelegateInvokeMethod будет иметь значение NULL.

EnumUnderlyingType

Для типов перечисления получает базовый тип. Возвращает значение NULL для всех других типов типов.

HasUnsupportedMetadata

Указывает, что этот символ использует метаданные, которые не поддерживаются языком.

Примеры приведены ниже.

  • Типы указателей в VB
  • Тип возвращаемого значения ByRef
  • Обязательные настраиваемые модификаторы

Это отличается, например, от ссылок на символы метаданных, определенные в сборках, на которые не ссылались. Символы, в которых возвращается значение true, никогда не могут использоваться успешно и поэтому никогда не должны отображаться в какой-либо функции интегрированной среды разработки.

Этот параметр задается для символов метаданных следующим образом:

  • Тип — если тип не поддерживается (например, тип указателя).
  • Метод — параметр или тип возвращаемого значения не поддерживается
  • Поле — тип не поддерживается
  • Событие — тип не поддерживается
  • Свойство — тип не поддерживается
  • Параметр — тип не поддерживается

(Унаследовано от ISymbol)
InstanceConstructors

Получение конструкторов экземпляров для этого типа.

Interfaces

Возвращает набор интерфейсов, непосредственно реализуемых этим типом. Этот набор не включает интерфейсы, которые являются базовыми интерфейсами непосредственно реализованных интерфейсов. Сюда входят интерфейсы, объявленные как ограничения для параметров типа.

(Унаследовано от ITypeSymbol)
IsAbstract

Возвращает значение, указывающее, является ли символ абстрактным.

(Унаследовано от ISymbol)
IsAnonymousType

Является ли это символом для анонимного типа (включая анонимный делегат VB).

(Унаследовано от ITypeSymbol)
IsComImport

Указывает, что класс или интерфейс импортирован из другого модуля. См. Import и ComImportAttribute.

IsDefinition

Возвращает значение, указывающее, является ли символ исходным определением. Возвращает значение false, если символ является производным от другого символа путем подстановки типа для экземпляра .

(Унаследовано от ISymbol)
IsExtern

Возвращает значение, указывающее, определен ли символ извне.

(Унаследовано от ISymbol)
IsFileLocal

Указывает, что тип объявлен в источнике и отображается только в файле, в который он объявлен.

IsGenericType

Значение true, если этот или какой-либо содержащий тип имеет параметры типа.

IsImplicitClass

Возвращает значение true, если тип является неявным классом, который удерживает недопустимые глобальные члены (например, методы или инструкции в файле, отличном от скрипта).

IsImplicitlyDeclared

Возвращает значение true, если этот символ был автоматически создан компилятором и не имеет явного соответствующего объявления исходного кода.

(Унаследовано от ISymbol)
IsNamespace

Возвращает значение true, если этот символ является пространством имен. Если это не пространство имен, это должен быть тип.

(Унаследовано от INamespaceOrTypeSymbol)
IsNativeIntegerType

Значение true, если тип представляет собственное целое число. В C# типы, представленные ключевыми словами языка nint и nuint.

(Унаследовано от ITypeSymbol)
IsOverride

Возвращает значение, указывающее, является ли символ переопределением символа базового класса.

(Унаследовано от ISymbol)
IsReadOnly

Значение true, если тип доступен только для чтения.

(Унаследовано от ITypeSymbol)
IsRecord

Для исходных символов значение true, если типом является запись. Для символов метаданных значение true, если типом является запись и ссылочный тип.

(Унаследовано от ITypeSymbol)
IsReferenceType

Значение true, если этот тип известен как ссылочный тип. Это никогда не так, что IsReferenceType и оба IsValueType возвращают true. Однако для параметра IsReferenceType неограниченного типа и IsValueType будут возвращать значение false.

(Унаследовано от ITypeSymbol)
IsRefLikeType

Значение true, если тип похож на ссылку, то есть он следует правилам, аналогичным переменным CLR by-ref. False, если тип не является ссылочный или язык не имеет понятия ссылочных типов.

(Унаследовано от ITypeSymbol)
IsScriptClass

Возвращает значение true, если типом является класс Script. Это может быть интерактивный класс отправки или класс Script в CSX-файле.

IsSealed

Возвращает значение, указывающее, запечатан ли символ.

(Унаследовано от ISymbol)
IsSerializable

Значение true, если тип сериализуемый (имеет флаг сериализуемых метаданных).

IsStatic

Возвращает значение, указывающее, является ли символ статическим.

(Унаследовано от ISymbol)
IsTupleType

Является ли это символом кортежа .

(Унаследовано от ITypeSymbol)
IsType

Возвращает значение true, если эти символы являются типом. Если это не тип, это должно быть пространство имен.

(Унаследовано от INamespaceOrTypeSymbol)
IsUnboundGenericType

Значение true, если это ссылка на несвязанный универсальный тип. Универсальный тип считается несвязанным , если все списки аргументов типа в его полном имени пусты. Обратите внимание, что аргументы типа несвязанного универсального типа будут возвращены как типы ошибок, так как они на самом деле не имеют аргументов типа. Несвязанный универсальный тип возвращает значение NULL для его BaseType и пустой результат для интерфейсов.

IsUnmanagedType

Значение true, если тип неуправляем в соответствии с языковыми правилами. False при управлении или если язык не имеет понятия неуправляемых типов.

(Унаследовано от ITypeSymbol)
IsValueType

Значение true, если этот тип известен как тип значения. Это никогда не так, что IsReferenceType и оба IsValueType возвращают true. Однако для параметра IsReferenceType неограниченного типа и IsValueType будут возвращать значение false.

(Унаследовано от ITypeSymbol)
IsVirtual

Возвращает значение, указывающее, является ли символ виртуальным.

(Унаследовано от ISymbol)
Kind

Возвращает объект , указывающий SymbolKind , какой тип символа.

(Унаследовано от ISymbol)
Language

Возвращает исходный язык ("C#" или "Visual Basic").

(Унаследовано от ISymbol)
Locations

Возвращает расположения, в которых символ был первоначально определен в источнике или метаданных. Некоторые символы (например, разделяемые классы) могут быть определены в нескольких расположениях.

(Унаследовано от ISymbol)
MemberNames

Возвращает коллекцию имен членов, объявленных в этом типе.

MetadataName

Возвращает имя символа, отображаемого в метаданных. В большинстве случаев это то же самое, что и свойство Name, за следующими исключениями:

  1. Имя метаданных универсальных типов включает суффикс "'1", "'2" и т. д., который указывает количество параметров типа (но не включает имена содержащих типов или пространств имен).
  2. Имя метаданных явных имен интерфейсов содержит пробелы, удаленные по сравнению со свойством name.
  3. Длина имен ограничена, чтобы не превышать ограничения метаданных.
(Унаследовано от ISymbol)
MetadataToken

Возвращает маркер метаданных, связанный с этим символом, или значение 0, если символ не загружается из метаданных.

(Унаследовано от ISymbol)
MightContainExtensionMethods

Определяет, может ли символ содержать методы расширения. Если значение равно false, символ не содержит методов расширения.

Name

Получает имя символа. Возвращает пустую строку, если она не именована.

(Унаследовано от ISymbol)
NativeIntegerUnderlyingType

Если это собственное целое число, возвращает символ для базового типа: IntPtr или UIntPtr. В противном случае возвращает значение NULL.

NullableAnnotation

Заметка, допускаемая значением NULL, связанная с типом, или None , если ее нет.

(Унаследовано от ITypeSymbol)
OriginalDefinition

Получите исходное определение этого символа типа. Если этот символ является производным от другого символа с помощью (скажем) подстановки типа, он получает исходный символ, как он был определен в источнике или метаданных.

SpecialType

Перечисленное значение, идентифицирующее определенные "специальные" типы, Objectнапример . Возвращает значение None , если тип не является специальным.

(Унаследовано от ITypeSymbol)
StaticConstructors

Получение статических конструкторов для этого типа.

TupleElements

Возвращает поля, представляющие элементы кортежа для типов кортежей.

Если этот тип не является кортежем, возвращает значение по умолчанию.

TupleUnderlyingType

Если это тип кортежа с именами элементов, возвращает символ для типа кортежа без имен. В противном случае возвращает значение NULL. Аргумент типа, соответствующий типу поля расширения (VT[8]. Rest), который находится в 8-й позиции (один на основе), всегда является символом для другого кортежа, а не его базового типа.

TypeArgumentNullableAnnotations

Возвращает допустимость значений NULL верхнего уровня аргументов типа, которые были заменены параметрами типа. Если для заданного параметра типа ничего не заменено, None возвращается для этого аргумента типа.

TypeArguments

Возвращает аргументы типа, заменяемые параметрами типа. Если заданный параметр типа не заменен, то аргументом типа считается сам параметр типа.

TypeArgumentsNullableAnnotations

Возвращает допустимость значений NULL верхнего уровня аргументов типа, которые были заменены параметрами типа. Если для заданного параметра типа ничего не заменено, NotApplicable возвращается для этого аргумента типа.

TypeKind

Перечисляемое значение, определяющее, является ли этот тип массивом, указателем, перечислением и т. д.

(Унаследовано от ITypeSymbol)
TypeParameters

Возвращает параметры типа, имеющиеся у этого типа. Если это не универсальный тип, возвращает пустой объект ImmutableArray.

Методы

Accept(SymbolVisitor)

Представляет тип, отличный от массива, указателя и параметра типа.

(Унаследовано от ISymbol)
Accept<TArgument,TResult>(SymbolVisitor<TArgument,TResult>, TArgument)

Представляет тип, отличный от массива, указателя и параметра типа.

(Унаследовано от ISymbol)
Accept<TResult>(SymbolVisitor<TResult>)

Представляет тип, отличный от массива, указателя и параметра типа.

(Унаследовано от ISymbol)
Construct(ImmutableArray<ITypeSymbol>, ImmutableArray<NullableAnnotation>)

Возвращает сконструированный тип с учетом аргументов типа и заметок, допускающих значение NULL.

Construct(ITypeSymbol[])

Возвращает сконструированный тип с учетом его аргументов типа.

ConstructUnboundGenericType()

Возвращает несвязанный универсальный тип этого именованного типа.

Equals(ISymbol, SymbolEqualityComparer)

Определяет, равен ли этот символ другому в соответствии с правилами предоставленного SymbolEqualityComparer

(Унаследовано от ISymbol)
FindImplementationForInterfaceMember(ISymbol)

Возвращает соответствующий символ в этом типе или базовом типе, реализующий interfaceMember (неявно или явно), или null, если такого символа не существует (это может быть вызвано тем, что этот тип не реализует контейнер interfaceMember или этот тип не предоставляет член, который успешно реализует interfaceMember).

(Унаследовано от ITypeSymbol)
GetAttributes()

Возвращает атрибуты для символа. Возвращает пустое IEnumerable<T> значение, если атрибуты отсутствуют.

(Унаследовано от ISymbol)
GetDocumentationCommentId()

Возвращает идентификатор комментария документации для символа или значение NULL, если символ не поддерживает комментарии к документации.

(Унаследовано от ISymbol)
GetDocumentationCommentXml(CultureInfo, Boolean, CancellationToken)

Возвращает XML-код (в виде текста) для комментария, связанного с символом .

(Унаследовано от ISymbol)
GetMembers()

Получение всех элементов этого символа.

(Унаследовано от INamespaceOrTypeSymbol)
GetMembers(String)

Получение всех элементов этого символа с определенным именем.

(Унаследовано от INamespaceOrTypeSymbol)
GetTypeArgumentCustomModifiers(Int32)

Возвращает настраиваемые модификаторы для аргумента типа, заменяемого параметром типа. Модификаторы соответствуют аргументу типа в том же порядковом номере в массиве TypeArguments . Возвращает пустой массив, если нет модификаторов.

GetTypeMembers()

Получает все члены этого символа, которые являются типами.

(Унаследовано от INamespaceOrTypeSymbol)
GetTypeMembers(String)

Получает все члены этого символа, которые являются типами с определенным именем любого arity.

(Унаследовано от INamespaceOrTypeSymbol)
GetTypeMembers(String, Int32)

Получение всех элементов этого символа, которые являются типами, имеющими определенное имя и arity

(Унаследовано от INamespaceOrTypeSymbol)
ToDisplayParts(NullableFlowState, SymbolDisplayFormat)

Преобразует символ в массив строковых частей, каждая из которых имеет тип . Полезно для раскраски отображаемой строки.

(Унаследовано от ITypeSymbol)
ToDisplayParts(SymbolDisplayFormat)

Преобразуйте символ в массив строковых частей, каждая из которых имеет тип . Полезно для раскраски отображаемой строки.

(Унаследовано от ISymbol)
ToDisplayString(NullableFlowState, SymbolDisplayFormat)

Преобразует ITypeSymbol состояние потока и , допускающее значение NULL, в строковое представление.

(Унаследовано от ITypeSymbol)
ToDisplayString(SymbolDisplayFormat)

Преобразует символ в строковое представление.

(Унаследовано от ISymbol)
ToMinimalDisplayParts(SemanticModel, Int32, SymbolDisplayFormat)

Преобразуйте символ в массив строковых частей, каждая из которых имеет тип . Может быть адаптировано к определенному расположению в исходном коде. Полезно для раскраски отображаемой строки.

(Унаследовано от ISymbol)
ToMinimalDisplayParts(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat)

Преобразуйте символ в массив строковых частей, каждая из которых имеет тип . Может быть адаптировано к определенному расположению в исходном коде. Полезно для раскраски отображаемой строки.

(Унаследовано от ITypeSymbol)
ToMinimalDisplayString(SemanticModel, Int32, SymbolDisplayFormat)

Преобразуйте символ в строку, которая может отображаться для пользователя. Может быть адаптировано к определенному расположению в исходном коде.

(Унаследовано от ISymbol)
ToMinimalDisplayString(SemanticModel, NullableFlowState, Int32, SymbolDisplayFormat)

Преобразует символ в строку, которая может отображаться для пользователя. Может быть адаптировано к определенному расположению в исходном коде.

(Унаследовано от ITypeSymbol)
WithNullableAnnotation(NullableAnnotation)

Возвращает тот же тип, что и этот тип, но с заданной заметкой, допускаемой значением NULL.

(Унаследовано от ITypeSymbol)

Методы расширения

IsMustOverride(ISymbol)

Представляет тип, отличный от массива, указателя и параметра типа.

IsNotOverridable(ISymbol)

Представляет тип, отличный от массива, указателя и параметра типа.

IsOverridable(ISymbol)

Представляет тип, отличный от массива, указателя и параметра типа.

IsOverrides(ISymbol)

Представляет тип, отличный от массива, указателя и параметра типа.

IsShared(ISymbol)

Определяет, является ли символ общим.

Применяется к