生成格式化成员
.NET 中的任何类型都实现了 ToString() 方法,该方法返回该类型对象的字符串表示。 为了为我们的类型返回有意义的字符串,我们通常需要重写 ToString() 方法。
ReSharper 允许您通过 生成格式设置成员 命令自动完成此例行操作。
根据 目标 C# 版本 ,ReSharper 要么使用插值字符串,要么使用 String.Format()。 请注意,您始终可以通过上下文操作
Alt+Enter
在它们之间进行转换。
在下面的示例中,此命令用于基于 _radius 和 _center 字段生成 ToString() 方法。
生成前 | 生成后 |
|---|---|
class Circle
{
int _radius;
Point _center;
}
|
class Circle
{
int _radius;
Point _center;
public override string ToString()
{
return $"{nameof(_radius)}: {_radius}, {nameof(_center)}: {_center}";
}
}
|
为格式化成员生成重写
在编辑器中,将插入符号放置在类型名称上或类型内您希望插入格式化成员重写的行上。 如果插入符号位于类型名称上,生成的代码将添加到类型声明的开头。
按 Alt+Insert 或从主菜单中选择 。 或者,您可以按 Control+Shift+A ,在弹出窗口中开始输入命令名称,然后在那里选择它。
在 生成 弹出窗口中,选择 格式化成员。
在出现的 生成 对话框中,选择要用于
ToString()重写的字段和/或自动属性。
如果您的类型中没有字段/属性,或者您未选择任何字段/属性,根据设置,ReSharper 将抛出新的
NotImplementedException(),返回默认值,或在生成的方法体中放置无法编译的代码。 您可以在 ReSharper 选项的 页面上配置设置。可选地,在对话框中使用以下控件:
ToString 已存在 — 如果
ToString()的实现已存在,则会显示,并允许您选择是否:替换已存在的方法。
将新生成的方法与现有方法并排放置。
完全跳过生成新方法。
使用 'nameof' — 如果 目标 C# 版本 高于 6.0,则会出现。 如果选中此复选框,ReSharper 将使用
nameof(symbol_name)定义符号的字符串表示,否则,它将自动计算字符串表示,例如,名为_radius的字段将呈现为"Radius"。
单击 完成 完成向导。
您还可以单击 选项 ,在 ReSharper 选项的 页面上查看或修改通用代码生成首选项。
您还可以通过在 生成 菜单中选择 Overriding Members 来生成重写,但在这种情况下,重写将返回 base.ToString()。
此功能在以下语言和技术中 受支持:
此处提供的说明和示例针对在 C# 中使用该功能。 有关其他语言的更多信息,请参阅 语言和框架 部分中的相应主题。