IEqualityComparer<;T>;不适用于List<;T>;.Distinct()方法
本文关键字:gt lt 方法 Distinct 不适用 IEqualityComparer 适用于 List | 更新日期: 2023-09-27 18:00:22
我有以下简单对象:
public class Net : IEqualityComparer<Net>
{
public string Name { get; private set; }
public int Id { get; set; }
private Gate _inGate;
private Gate _outGate;
private NetValue _value = NetValue.NotSet;
private bool _isMiddleNet;
//constructor and stuff!!!.....
//Equality comparer
public bool Equals(Net x, Net y)
{
return (x.Id == y.Id && x.Name == y.Name);
}
public int GetHashCode(Net obj)
{
return obj.Id.GetHashCode() ^ obj.Name.GetHashCode();
}
public override int GetHashCode()
{
return 13 * Id.GetHashCode() + 7 * Name.GetHashCode();
}
所以基本上我有兴趣说这个对象的两个实例是相等的,当且仅当它们的Id
和Name
成员相等。。。
但在另一个类的其他地方,我必须使用List<Net>
,并且我想对这些列表进行区分:
inputNetsA = inputNetsA.Distinct().ToList();
inputNetsB = inputNetsB.Distinct().ToList();
但这永远都不起作用!我做错了什么?
您需要将对象设为IEquatable<T>
。IEqualityComparer<T>
是用于将两个对象相互比较的对象的接口。IEquatable<T>
用于将一个对象与另一个相同类型的对象进行比较。
否则,如果您想使用IEqualityComparer<T>
,它就意味着要传递给Distinct()
方法。
// better to extend off of EqualityComparer<T> instead of
// implementing IEqualityComparer<T> directly
public class NetComparer : EqualityComparer<Net>
{
public override bool Equals(Net x, Net y)
{
return (x.Id == y.Id && x.Name == y.Name);
}
public override int GetHashCode(Net obj)
{
return obj.Id.GetHashCode() ^ obj.Name.GetHashCode();
}
}
inputNetsA = inputNetsA.Distinct(new NetComparer()).ToList();