我已经定义了一个带有字符串成员的 C# 类。出于所有目的,将此类视为字符串的子类(除非这是不允许的)。我用它来表示一个与特定格式匹配的强类型字符串字段(我已经大大简化了这一点)。
public class field
{
private readonly string m_field;
public field(string init_value)
{
//Check the syntax for errors
if (CheckSyntax(init_value))
{
m_field = init_value;
}
else
{
throw new ArgumentOutOfRangeException();
}
}
public override string ToString()
{
return m_field;
}
}
现在,我希望能够将此类直接与任何其他字符串(对象或文字)进行比较。因此,我在课堂上实现了以下内容:
public override bool Equals(object obj)
{
if (obj == null)
{
return false;
}
return this.m_field == obj.ToString();
}
public override int GetHashCode()
{
return this.m_field.GetHashCode();
}
public static bool operator ==(field x, Object y)
{
if ((object)x == null && y == null)
{
return true;
}
else if ((object)x == null || y == null)
{
return false;
}
else
{
return (x.m_field == y.ToString());
}
}
public static bool operator !=(field x, Object y)
{
return !(x == y);
}
现在,当我编写单元测试时,根据我将参数传递给 Assert.AreEqual 的顺序,我会得到不同的结果:
string valid = "Some String";
field target = new field(valid);
Assert.AreEqual(target, valid); // PASSES
Assert.AreEqual(valid, target); // FAILS
我假设这是因为在第一个断言中,它调用了 field.Equals(),而在第二个断言中,它调用了 String.Equals()。显然我从错误的角度来处理这个问题。谁能给我一些见解?
另一件事。我不能在这里使用结构(值类型),因为在我的实际情况下,我在基类中定义所有这些并从它继承。