财产 | 价值 |
---|---|
规则 ID | IDE0064 |
标题 | 使结构字段可写 |
类别 | CodeQuality |
子类别 | 语言规则(修饰符首选项) |
适用的语言 | C# |
概述
此规则检测包含一个或多个 readonly
字段的结构,并包含对构造函数外部 this
的赋值。 此规则建议将 readonly
字段转换为非只读,即可写。 将此类结构字段标记为 readonly
可能会导致意外行为,因为分配给字段的值在构造函数外部分配 this
时可能会更改。
选项
此规则没有关联的代码样式选项。
例
// Code with violations
struct MyStruct
{
public readonly int Value;
public MyStruct(int value)
{
Value = value;
}
public void Test()
{
this = new MyStruct(5);
}
}
// Fixed code
struct MyStruct
{
public int Value;
public MyStruct(int value)
{
Value = value;
}
public void Test()
{
this = new MyStruct(5);
}
}
禁止显示警告
如果只想取消单个冲突,请将预处理器指令添加到源文件以禁用,然后重新启用规则。
#pragma warning disable IDE0064
// The code that's violating the rule is on this line.
#pragma warning restore IDE0064
若要禁用文件、文件夹或项目的规则,请将其严重性设置为 配置文件中的 none
。
[*.{cs,vb}]
dotnet_diagnostic.IDE0064.severity = none
若要禁用此整个规则类别,请将类别的严重性设置为 配置文件中的 none
。
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-CodeQuality.severity = none
有关详细信息,请参阅 如何取消代码分析警告。