Ескертпе
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Жүйеге кіруді немесе каталогтарды өзгертуді байқап көруге болады.
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Каталогтарды өзгертуді байқап көруге болады.
| Свойство | Значение |
|---|---|
| Идентификатор правила | CA1309 |
| Заголовок | Используйте порядковый параметр StringComparison |
| Категория | Глобализация |
| Исправление является критическим или не критическим | неразрывный |
| Включен по умолчанию в .NET 10 | Нет |
| Применимые языки | C# и Visual Basic |
Причина
Операция сравнения строк, не являющаяся лингвистической, не задает для параметра StringComparison значение Ordinal или значение OrdinalIgnoreCase.
Описание правила
Многие операции со строками, особенно методы System.String.Compare и System.String.Equals, теперь поддерживают перегрузку, которая принимает значение перечисления System.StringComparison в качестве параметра.
Когда вы указываете StringComparison.Ordinal или StringComparison.OrdinalIgnoreCase, сравнение строк не является лингвистическим. Таким образом, при принятии решений по сравнению игнорируются особенности, характерные для естественного языка. Игнорирование особенностей естественного языка означает, что решения принимаются на основе простых сравнений байтов, а не на основе таблиц регистров и эквивалентности, которые параметризуются с учётом культуры. В результате при явной установке параметра значения StringComparison.Ordinal или StringComparison.OrdinalIgnoreCase ваш код часто обретает надежность, точность и быстродействие.
Устранение нарушений
Чтобы устранить нарушение этого правила, измените метод сравнения строк на перегруженную версию, принимающую в качестве параметра перечисление System.StringComparison и укажите либо Ordinal, либо OrdinalIgnoreCase. Например, измените String.Compare(str1, str2) на String.Compare(str1, str2, StringComparison.Ordinal).
Когда лучше отключить предупреждения
Предупреждение из этого правила можно отключить, если библиотека или приложение предназначены для ограниченной локальной аудитории, или если необходимо использовать семантику текущей культуры.
Отключение предупреждений
Если вы просто хотите отключить одно нарушение, добавьте директивы препроцессора в исходный файл, чтобы отключить и повторно включить правило.
#pragma warning disable CA1309
// The code that's violating the rule is on this line.
#pragma warning restore CA1309
Чтобы отключить правило для файла, папки или проекта, задайте его серьезность none в файле конфигурации.
[*.{cs,vb}]
dotnet_diagnostic.CA1309.severity = none
Дополнительные сведения см. в разделе Практическое руководство. Скрытие предупреждений анализа кода.