值
规则 ID
CA1008
类别
设计
修复是中断修复还是非中断修复
非中断 - 如果系统提示你向无标志枚举添加 None 值。 中断 - 如果系统提示你重命名或删除任何枚举值。
原因
没有应用 System.FlagsAttribute 的枚举不定义值为零的成员。 或者,已应用 FlagsAttribute 的枚举定义值为零但其名称不为“None”的成员。 或者,枚举定义多个零值成员。
默认情况下,此规则仅查看外部可见的枚举,但这是可配置的。
规则说明
像其他值类型一样,未初始化枚举的默认值为零。 无标志特性的枚举应定义值为零的成员,这样默认值即为该枚举的有效值。 如果可行,请将成员命名为“None”。 否则,将零赋给最常使用的成员。 默认情况下,如果未在声明中设置第一个枚举成员的值,则其值为零。
如果应用了 FlagsAttribute 的枚举定义值为零成员,则该成员的名称应为“None”,以指示枚举中尚未设置值。 将值为零的成员用于任何其他目的与使用 FlagsAttribute 存在冲突,因为 AND 和 OR 位运算符对成员没有意义。 这意味着,只应为一个成员分配零值。 如果有多个零值成员在标志特性的枚举中出现,对于不为零的成员,Enum.ToString() 将返回不正确的结果。
如何解决冲突
若要解决无标志特性枚举与此规则的冲突,请定义值为零的成员,这是一项非中断性变更。 对于定义零值成员的标志特性枚举,请将此成员命名为“None”,并删除值为零的任何其他成员,这是一项中断性变更。
何时禁止显示警告
不要禁止显示此规则发出的警告,但之前已发布的标志特性枚举除外。
抑制警告
可以通过多种方式来禁止显示代码分析警告,包括禁用项目的规则、使用预处理器指令为特定代码行禁用该规则或应用 SuppressMessageAttribute 特性。 有关详细信息,请参阅如何禁止显示代码分析警告。
配置代码以进行分析
使用下面的选项来配置代码库的哪些部分要运行此规则。
包含特定的 API 图面
你可以仅为此规则、为所有规则或为此类别中的所有规则配置此选项(设计)。 有关详细信息,请参阅代码质量规则配置选项。
包含特定的 API 图面
你可以根据代码库的可访问性,配置要针对其运行此规则的部分。 例如,若要指定规则应仅针对非公共 API 图面运行,请将以下键值对添加到项目中的 .editorconfig 文件:
dotnet_code_quality.CAXXXX.api_surface = private, internal
示例
下面的示例演示两个满足规则的枚举和一个违反规则的枚举 BadTraceOptions。
using System;
namespace ca1008
{
public enum TraceLevel
{
Off = 0,
Error = 1,
Warning = 2,
Info = 3,
Verbose = 4
}
[Flags]
public enum TraceOptions
{
None = 0,
CallStack = 0x01,
LogicalStack = 0x02,
DateTime = 0x04,
Timestamp = 0x08,
}
[Flags]
public enum BadTraceOptions
{
CallStack = 0,
LogicalStack = 0x01,
DateTime = 0x02,
Timestamp = 0x04,
}
class UseBadTraceOptions
{
static void MainTrace()
{
// Set the flags.
BadTraceOptions badOptions =
BadTraceOptions.LogicalStack | BadTraceOptions.Timestamp;
// Check whether CallStack is set.
if ((badOptions & BadTraceOptions.CallStack) ==
BadTraceOptions.CallStack)
{
// This 'if' statement is always true.
}
}
}
}
Imports System
Namespace ca1008
Public Enum TraceLevel
Off = 0
AnError = 1
Warning = 2
Info = 3
Verbose = 4
End Enum
<Flags>
Public Enum TraceOptions
None = 0
CallStack = &H1
LogicalStack = &H2
DateTime = &H4
Timestamp = &H8
End Enum
<Flags>
Public Enum BadTraceOptions
CallStack = 0
LogicalStack = &H1
DateTime = &H2
Timestamp = &H4
End Enum
Class UseBadTraceOptions
Shared Sub Main1008()
' Set the flags.
Dim badOptions As BadTraceOptions =
BadTraceOptions.LogicalStack Or BadTraceOptions.Timestamp
' Check whether CallStack is set.
If ((badOptions And BadTraceOptions.CallStack) =
BadTraceOptions.CallStack) Then
' This 'If' statement is always true.
End If
End Sub
End Class
End Namespace
相关规则
CA2217:不要使用 FlagsAttribute 标记枚举
CA1700:不要命名“Reserved”枚举值
CA1712:不要将类型名用作枚举值的前缀
CA1028:枚举存储应为 Int32
CA1027:用 FlagsAttribute 标记枚举
另请参阅
System.Enum
本文系外文翻译,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文系外文翻译,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有