【发布时间】:2018-03-03 00:21:45
【问题描述】:
我已经使用了允许代码生成的 ReSharper 功能一段时间了。我一直这样做的方法是在我的班级中按 Alt-Enter(在任何方法之外),或按 Alt-Ins,然后选择 Equality members,然后选择所有成员并单击确定。
这样做时会生成的代码是这样的:
public class Foo
{
public int Bar { get; }
public int Baz { get; }
protected bool Equals(Foo other)
{
return Bar == other.Bar
&& Baz == other.Baz;
}
public override bool Equals(object obj)
{
if (ReferenceEquals(null, obj)) return false;
if (ReferenceEquals(this, obj)) return true;
if (obj.GetType() != this.GetType()) return false;
return Equals((Foo) obj);
}
public override int GetHashCode()
{
unchecked
{
return (Bar * 397) ^ Baz;
}
}
}
尽管最近(可能随着 ReSharper 2017 或次要版本的发布?),按 Alt-Enter 会带来另一个菜单,其中包含一个 Generate Equals 和 GetHashCode 项,它会生成这种代码而是:
public class Foo
{
public int Bar { get; }
public int Baz { get; }
public override bool Equals(object obj)
{
var foo = obj as Foo;
return foo != null &&
Bar == foo.Bar &&
Baz == foo.Baz;
}
public override int GetHashCode()
{
var hashCode = 997021164;
hashCode = hashCode * -1521134295 + Bar.GetHashCode();
hashCode = hashCode * -1521134295 + Baz.GetHashCode();
return hashCode;
}
}
奇怪的是,按 Alt-Insert 仍然会生成与以前相同的代码。现在似乎 ReSharper 会根据我们生成它的方式生成两个不同的模板。差异似乎非常显着,使用了不同的素数,并且丢失了 unchecked 关键字。
我很熟悉在第一个版本中使用素数 397 的原因,但我找不到第二个版本的任何解释,甚至在 ReSharper 在线帮助中也找不到。 Feed 整数(本例中为 997021164)似乎也会根据要比较的属性数量而变化。
有人对此有解释吗?
【问题讨论】:
-
ReSharper 回答了这个问题,关于 Roslyn 使用的算法的解释参见stackoverflow.com/questions/32808566/…
标签: c# hash resharper gethashcode resharper-2017