CA1716: идентификаторы не должны совпадать с ключевыми словами
Свойство | Значение |
---|---|
Идентификатор правила | CA1716 |
Заголовок | Идентификаторы не должны совпадать с ключевыми словами |
Категория | Именование |
Исправление является критическим или не критическим | Критическое |
Включен по умолчанию в .NET 9 | No |
Причина
Имя пространства имен, типа, виртуального элемента или элемента интерфейса совпадает с зарезервированным ключевым словом в языке программирования.
По умолчанию это правило рассматривает только пространства имен, типы и элементы, видимые извне, но вы можете настроить видимость и виды символов.
Описание правила
Идентификаторы пространств имен, типов, виртуальных элементов и элементов интерфейсов не должны совпадать с ключевыми словами, определенными в языках, поддерживаемых в среде CLR. В зависимости от используемого языка и конкретного ключевого слова ошибки и неоднозначности компилятора могут усложнить использование библиотеки.
Это правило проверяет совпадение с ключевыми словами в следующих языках:
- Visual Basic
- C#
- C++/CLI
Для Visual Basic сравнение выполняется без учета регистра, а для других языков — с учетом регистра.
Устранение нарушений
Выберите имя, которого нет в списке ключевых слов.
Когда лучше отключить предупреждения
Вы можете отключить предупреждение из этого правила, если вы уверены, что идентификатор не будет путать пользователей API, и что библиотека доступна на всех доступных языках в .NET.
Отключение предупреждений
Если вы просто хотите отключить одно нарушение, добавьте директивы препроцессора в исходный файл, чтобы отключить и повторно включить правило.
#pragma warning disable CA1716
// The code that's violating the rule is on this line.
#pragma warning restore CA1716
Чтобы отключить правило для файла, папки или проекта, задайте его серьезность none
в файле конфигурации.
[*.{cs,vb}]
dotnet_diagnostic.CA1716.severity = none
Дополнительные сведения см. в разделе Практическое руководство. Скрытие предупреждений анализа кода.
Настройка кода для анализа
Используйте следующие параметры, чтобы указать части базы кода, к которым будет применяться это правило.
Эти параметры можно настроить только для этого правила, для всех правил, к которым она применяется, или для всех правил в этой категории (именование), к которым она применяется. Дополнительные сведения см. в статье Параметры конфигурации правила качества кода.
Включение определенных контактных зон API
Вы можете настроить, для каких частей базы кода следует выполнять это правило в зависимости от их доступности. Например, чтобы указать, что правило должно выполняться только для закрытой контактной зоны API, добавьте следующую пару "ключ-значение" в файл EDITORCONFIG в своем проекте:
dotnet_code_quality.CAXXXX.api_surface = private, internal
Заметка
Замените XXXX
частью CAXXXX
идентификатором применимого правила.
Проанализированные типы символов
Вы можете настроить типы символов, которые будут анализироваться этим правилом. Допустимые значения:
Namespace
NamedType
Method
Property
Event
Parameter
Для разделения значений используйте запятые (,
). Значение по умолчанию включает все виды символов из предыдущего списка.
dotnet_code_quality.CA1716.analyzed_symbol_kinds = Namespace, NamedType, Method, Property, Event