CA1858: Usar "StartsWith" en lugar de IndexOf

Propiedad Value
Identificador de la regla CA1858
Título Usar StartsWith en lugar de IndexOf
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

Se llama a String.IndexOf y se compara su resultado con cero.

Descripción de la regla

Es más eficaz y más claro llamar a String.StartsWith que llamar a String.IndexOf y comparar el resultado con cero para determinar si una cadena comienza con un prefijo determinado.

IndexOf busca en toda la cadena, mientras que StartsWith solo en el principio de la cadena.

Cómo corregir infracciones

Reemplace la llamada a String.IndexOf por una llamada a String.StartsWith.

Ejemplo

El siguiente fragmento de código muestra una infracción de la regla CA1858:

bool M(string s)
{
    return s.IndexOf("abc") == 0;
}
Function M(s As String) As Boolean
    Return s.IndexOf("abc") = 0
End Function

El siguiente fragmento de código corrige la infracción:

bool M(string s)
{
    return s.StartsWith("abc");
}
Function M(s As String) As Boolean
    Return s.StartsWith("abc")
End Function

Cuándo suprimir las advertencias

Es seguro suprimir esta advertencia si el rendimiento no es un problema.

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 CA1858
// The code that's violating the rule is on this line.
#pragma warning restore CA1858

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.CA1858.severity = none

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