使结构字段可写(IDE0064)

财产 价值
规则 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

有关详细信息,请参阅 如何取消代码分析警告

另请参阅