前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CA1720:标识符不应包含类型名称

CA1720:标识符不应包含类型名称

作者头像
呆呆
发布2022-02-19 18:43:28
4790
发布2022-02-19 18:43:28
举报
文章被收录于专栏:centosDai

规则 ID

CA1720

类别

命名

修复是中断修复还是非中断修复

重大

原因

成员中的参数名称包含数据类型名称。

-或-

成员的名称包含语言特定的数据类型名称。

默认情况下,此规则仅查看外部可见的成员,但这可配置。

规则说明

参数和成员的名称更好地用于传达其含义而不是描述其类型,类型描述通常由开发工具提供。 对于成员的名称,如果必须使用数据类型名称,请使用与语言无关的名称,而不要使用语言特定的名称。 例如,请使用与语言无关的数据类型名称 Int32,而不要使用 C# 类型名称 int。

参数或成员名称中的每个离散标记都会对照以下语言特定的数据类型名称进行检查(不区分大小写):

Bool

WChar

Int8

UInt8

Short

UShort

int

UInt

Integer

UInteger

Long

ULong

无符号

有符号

Float

Float32

Float64

此外,参数的名称还会对照以下与语言无关的数据类型名称进行检查(不区分大小写):

对象

布尔

Char

字符串

SByte

Byte

UByte

Int16

UInt16

Int32

UInt32

Int64

UInt64

IntPtr

Ptr

指针

UInptr

UPtr

UPointer

Single

Double

小数

GUID

如何解决冲突

如果针对参数触发:

将参数名称中的数据类型标识符替换为一个可更好地描述其含义的词或更通用的词,如“value”。

如果针对成员触发:

将成员名称中的语言特定数据类型标识符替换为一个可更好地描述其含义的词、与语言无关的等效词或更通用的词,如“value”。

何时禁止显示警告

如果偶尔使用基于类型的参数和成员名称,则可禁止显示警告。 但对于新开发,没有任何已知情况应该禁止显示此规则的警告。 对于以前发布的库,可能有必要禁止显示此规则的警告。

配置代码以进行分析

使用下面的选项来配置代码库的哪些部分要运行此规则。

包含特定的 API 图面

你可以仅为此规则、为所有规则或为此类别(命名)中的所有规则配置此选项。 有关详细信息,请参阅代码质量规则配置选项。

包含特定的 API 图面

你可以根据代码库的可访问性,配置要针对其运行此规则的部分。 例如,若要指定规则应仅针对非公共 API 图面运行,请将以下键值对添加到项目中的 .editorconfig 文件:

dotnet_code_quality.CAXXXX.api_surface = private, internal

相关规则

CA1708:标识符应以大小写之外的差别进行区分

CA1707:标识符不应包含下划线

本文系外文翻译,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系外文翻译前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档