Compartir a través de


CA1847: Use String.Contains(char) en lugar de String.Contains(string) con caracteres únicos.

Propiedad Value
Identificador de la regla CA1847
Título Use String.Contains(char) en lugar de String.Contains(string) con caracteres únicos.
Categoría Rendimiento
La corrección es problemática o no problemática Poco problemático
Habilitado de forma predeterminada en .NET 8 Como sugerencia

Causa

String.Contains(string) se usa cuando String.Contains(char) está disponible.

Descripción de la regla

Al buscar un solo carácter, String.Contains(char) ofrece un mejor rendimiento que String.Contains(string).

Cómo corregir infracciones

En general, la regla se fija simplemente mediante un literal char en lugar de un literal de cadena.

public bool ContainsLetterI()
{
    var testString = "I am a test string.";
    return testString.Contains("I");
}
Public Function ContainsLetterI() As Boolean
    Dim testString As String = "I am a test string."
    Return testString.Contains("I")
End Function

Este código se puede cambiar para usar un literal char en su lugar.

public bool ContainsLetterI()
{
    var testString = "I am a test string.";
    return testString.Contains('I');
}
Public Function ContainsLetterI() As Boolean
    Dim testString As String = "I am a test string."
    Return testString.Contains("I"c)
End Function

Cuándo suprimir las advertencias

Suprima una infracción de esta regla si no le preocupa el impacto en el rendimiento de la invocación de búsqueda en cuestión.

Supresión de una advertencia

Si solo quiere suprimir una única infracción, agregue directivas de preprocesador al archivo de origen para deshabilitar y volver a habilitar la regla.

#pragma warning disable CA1847
// The code that's violating the rule is on this line.
#pragma warning restore CA1847

Para deshabilitar la regla de un archivo, una carpeta o un proyecto, establezca su gravedad en none del archivo de configuración.

[*.{cs,vb}]
dotnet_diagnostic.CA1847.severity = none

Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.

Vea también