Partilhar via


CA1830: Prefira as sobrecargas fortemente tipadas dos métodos Append e Insert no StringBuilder

Propriedade valor
ID da regra CA1830
Título Prefira o sobrecarregamento de métodos fortemente tipados Append e Insert no StringBuilder
Categoria Desempenho
A correção causa interrupção ou não Ininterrupto
Habilitado por padrão no .NET 10 Como sugestão
Línguas aplicáveis C# e Visual Basic

Motivo

Foi chamado um método StringBuilderAppend ou Insert com um argumento que era o resultado de chamar ToString em um tipo para o qual o método Append ou Insert tem uma sobrecarga dedicada.

Descrição da regra

Append e Insert fornecem sobrecargas para vários tipos além de String. Quando possível, prefira as sobrecargas tipadas fortemente em vez de usar ToString() e a sobrecarga baseada em string.

Como corrigir violações

Elimine o desnecessário ToString() da invocação.

using System.Text;

class C
{
    int _value;

    // Violation
    public void Log(StringBuilder destination)
    {
        destination.Append("Value: ").Append(_value.ToString()).AppendLine();
    }

    // Fixed
    public void Log(StringBuilder destination)
    {
        destination.Append("Value: ").Append(_value).AppendLine();
    }
}

Quando suprimir avisos

É seguro suprimir uma violação desta regra se não estiveres preocupado com o impacto no desempenho de alocações desnecessárias de strings.

Suprimir um aviso

Se você quiser apenas suprimir uma única violação, adicione diretivas de pré-processador ao seu arquivo de origem para desativar e, em seguida, reativar a regra.

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

Para desabilitar a regra de um arquivo, pasta ou projeto, defina sua gravidade como none no arquivo de configuração.

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

Para obter mais informações, consulte Como suprimir avisos de análise de código.

Consulte também