CA1830: preferisce overload di metodo Append e Insert fortemente tipizzato in StringBuilder
Proprietà | valore |
---|---|
ID regola | CA1830 |
Title | Preferire gli overload di metodi Append e Insert fortemente tipizzati su StringBuilder |
Categoria | Prestazioni |
La correzione causa un'interruzione o meno | Non causa un'interruzione |
Abilitato per impostazione predefinita in .NET 9 | Come suggerimento |
Causa
Un StringBuilder Append
metodo o Insert
è stato chiamato con un argomento che è il risultato della chiamata ToString
a un tipo per il quale il Append
metodo o Insert
ha un overload dedicato.
Descrizione regola
Append e Insert forniscono overload per più tipi oltre String. Quando possibile, preferire gli overload fortemente tipizzato rispetto all'uso di ToString() e dell'overload basato su stringhe.
Come correggere le violazioni
Eliminare l'oggetto non necessario ToString()
dalla chiamata.
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 eliminare gli avvisi
È possibile eliminare una violazione di questa regola se non si è interessati all'impatto sulle prestazioni dalle allocazioni di stringhe non necessarie.
Eliminare un avviso
Se si vuole eliminare una singola violazione, aggiungere direttive del preprocessore al file di origine per disabilitare e quindi riabilitare la regola.
#pragma warning disable CA1830
// The code that's violating the rule is on this line.
#pragma warning restore CA1830
Per disabilitare la regola per un file, una cartella o un progetto, impostarne la gravità none
su nel file di configurazione.
[*.{cs,vb}]
dotnet_diagnostic.CA1830.severity = none
Per altre informazioni, vedere Come eliminare gli avvisi di analisi del codice.