最近,在使用LinqToXml的时候,使用到其中一个重要的类:XName。它表示一个XML元素/XML属性的“名字”。 System.Xml.Linq中的API,大量使用了这个类,如:
不过还好,我们不用每次都显式的new一个XName类的实例,因为它实现了从string类到它的隐式转换:
public static implicit operator XName(string expandedName);
这样使得我们在使用的过程中,可以很简单的直接使用linqtoxml的API。如:
XElement person = new XElement("Person");
person.Attribute("Name").Value = "Name";
同时,由于它也和string类一样,使用了隐式的操作符== 和 !=,所以我们在对它的实例进行判定时,可以使用以下方法:
XName name1 = "name";
XName name2 = "name";
if (name1 == name2)
{
//do something
}
当我使用Reflector查看到这个操作符的实现时,它居然是下面这样的!?
也就是说,它的所有判断相等性,都是使用==操作符,但是这个操作符的实现居然是调用它自己。
我想,可能是reflector生成的C#有问题,不过查看IL后,也是一样的结果。所以我就写了一个类进行验证:
public class Name
{
public static bool operator ==(Name left, Name right)
{
return (left == right);
}
public static bool operator !=(Name left, Name right)
{
return !(left == right);
}
public static void Test()
{
Name name1 = new Name();
Name name2 = new Name();
if (name1 == name2)
{
//do nothing
}
}
}
结果是:
果然是不能这样写,但是XName为什么可以呢?