CA1307: Specify StringComparison
Note
This article applies to Visual Studio 2015. If you're looking for the latest Visual Studio documentation, see Visual Studio documentation. We recommend upgrading to the latest version of Visual Studio. Download it here
Item | Value |
---|---|
TypeName | SpecifyStringComparison |
CheckId | CA1307 |
Category | Microsoft.Globalization |
Breaking Change | Non-breaking |
Cause
A string comparison operation uses a method overload that does not set a StringComparison parameter.
Rule Description
Many string operations, most important the Compare and Equals methods, provide an overload that accepts a StringComparison enumeration value as a parameter.
Whenever an overload exists that takes a StringComparison parameter, it should be used instead of an overload that does not take this parameter. By explicitly setting this parameter, your code is often made clearer and easier to maintain.
How to Fix Violations
To fix a violation of this rule, change string comparison methods to overloads that accept the StringComparison enumeration as a parameter. For example: change String.Compare(str1, str2)
to String.Compare(str1, str2, StringComparison.Ordinal)
.
When to Suppress Warnings
It is safe to suppress a warning from this rule when the library or application is intended for a limited local audience and will therefore not be localized.