| 属性 | 值 |
|---|---|
| 规则 ID | CA1830 |
| 标题 | 在 StringBuilder 中优先使用强类型化的 Append 和 Insert 方法重载 |
| 类别 | “性能” |
| 修复会引起中断还是不会引起中断 | 非中断 |
| 在 .NET 10 中默认启用 | 作为一种建议 |
| 适用的语言 | C# 和 Visual Basic |
原因
调用 StringBuilderAppend 或 Insert 方法时,传递的参数来自于在某种类型上调用 ToString 产生的结果,而该类型有对 Append 或 Insert 方法的专用重载。
规则说明
Append 和 Insert 为除 String 之外的多种类型提供重载。 在可能的情况下,请优先使用强类型重载,而不是使用 ToString() 和基于字符串的重载。
如何解决违规
从调用中删除不必要的 ToString()。
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();
}
}
何时禁止显示警告
如果不关心不必要的字符串分配对性能的影响,可以忽略对此规则的违反。
抑制警告
如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。
#pragma warning disable CA1830
// The code that's violating the rule is on this line.
#pragma warning restore CA1830
若要对文件、文件夹或项目禁用该规则,请在none中将其严重性设置为 。
[*.{cs,vb}]
dotnet_diagnostic.CA1830.severity = none
有关详细信息,请参阅如何禁止显示代码分析警告。