List求交并补集--IEqualityComparer实现

 

问题:

  

两个List<Student>,求交、并、补集。

 

解决办法:

用直接调用List里面的现成方法来解决,不过当数据量大的时候,这时不可行的。anyway,先看这个吧(以求交集为例)。

实现IEqualityComparer接口
public class StudentListEquality : IEqualityComparer<Student>

   {

       public bool Equals(Student x, Student y)

       {

           return x.StudentId == y.StudentId;

       }



       public int GetHashCode(Student obj)

       {

           if (obj == null)

           {

               return 0;

           }

           else

           {

                return obj.ToString() .GetHashCode();

           }

       }

   }
调用Intersect方法
List<Student> oldStudentList={...};

List<Student> newStudentList={...};

 

List<Student>studnetsCommon=oldStudentList.Intersect(

              newStudentList, new StudentListEquality()).ToList();

 

原因:

     C#中,求两个List的交集/并集/补集,可以调用List类中的Intersect,Union和Except方法,但是它会要去你提供指定的等值比较器,也就是自己实现IEqualityComparer接口。当然如果没有提供,则是按照默认的比较器来判断,结果可能会与你的初衷相悖。
    等值比较器是根据自己的需求写的。上面的代码中实现了IEqualityCompare接口,用来判断两个student是否是同一个。但我只是写了根据StudentId是否相同来判断,当然也可以传递参数,指定具体比较对象的哪个属性。 这就需要用到枚举类型了,详细可以参看我的另外一篇: List<>根据指定属性排序(实现IComparer接口)

 

你可能感兴趣的:(compare)