object类中存在'Equal‘和'GetHashcode’方法,我们的类型继承了object基类。直接实现对象的两个方法和使用IComparer接口有什么不同?
如果我们覆盖object的Equal和GetHashCode,并推送到哈希表,它将使用覆盖环的equal方法?
新的哈希表和IEqualityComparer构造函数有什么不同?
发布于 2011-10-13 16:15:41
当需要对对象进行“排序”时,可以使用IComparable接口,它提供了一个方法(CompareTo),该方法可以告诉您两个对象是<、=还是>。使用IEqualityComparer的构造函数允许您提供一个特定的Equals/GetHashCode,它可以不同于您的对象所定义的那些。通常,Hashtable将使用被覆盖的对象Equals和GetHashCode (或基本object、Equals和GetHashCode)。
举个例子,标准字符串以区分大小写的方式进行比较("A" != "a"),但是您可以创建一个IEqualityComparer帮助器类,使其能够以不区分大小写的方式对字符串进行散列。(从技术上讲,这个类已经存在于多种变体中:它们被称为StringComparer.InvariantCultureIgnoreCase,以及所有其他返回StringComparer对象的StringComparer静态方法,该对象实现了IComparer、IEqualityComparer、IComparer<string>、IEqualityComparer<string>)
注意,Hashtable使用IEqualityComparer可选参数,而不是泛型版本的IEqualityComparer<T>,因为Hashtable是预泛型的。
发布于 2011-10-13 16:24:13
IComparer接口(通用接口和非通用接口)允许您比较两个实例。
Compare方法允许您将对象本身与另一个实例进行比较。当然,当当前实例为空时,您将在本例中获得一个NullReferenceException,因为您在“空”实例上调用Compare。实现IComparer的类可以解决这个问题。
因此,当您实现IComparer接口时,您将拥有一个具有“Compare”方法的类,该方法可以像这样调用:
public class MyObjectComparer : IComparer<MyObject>
{
public int Compare( MyObject first, MyObject second )
{
// implement logic here to determine whether first is less, greater or equal then second.
}
}这使您可以执行以下操作:
var c = new MyObjectComparer();
var one = new MyObject();
var two = new MyObject();
c.Compare (one, two);当您使用指定IEqualityComparer实例的构造函数实例化Hashtable时,这意味着给定的IEqualityComparer将用于确定某个键是否已经存在于哈希表中。
否则,将使用key-object的Compare方法。
https://stackoverflow.com/questions/7751170
复制相似问题