我有以下代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace TestSomethingRelatedToLINQ
{
class Person : IEqualityComparer<Person>
{
internal int personID;
internal string PersonName;
public bool Equals(Person x, Person y)
{
return x.personID == y.personID;
}
public int GetHashCode(Person obj)
{
return obj.personID.GetHashCode();
}
}
class Program
{
static void Main(string[] args)
{
List<Person> list1 = new List<Person>{
new Person{personID = 1 , PersonName = "Ali"},
new Person{personID = 2 , PersonName = "Ali1"},
new Person{personID = 3 , PersonName = "Ali2"}
};
List<Person> list2 = new List<Person>{
new Person{personID = 4 , PersonName = "Habib1"},
new Person{personID = 2 , PersonName = "Habib2"},
new Person{personID = 5 , PersonName = "Habib3"}
};
}
}
}
我需要选择list1中的所有元素,list2中没有personID的所有元素都存在于List1中,然后按personID排序结果
新输出应该像
1, Ali
2, Ali1
3, Ali2
4, Habib1
5, Habib3
任何想法如何使用
答案 0 :(得分:2)
首先调用LINQ Concat,以便将List 2附加到List 1。
然后调用LINQ Distinct,它将删除重复的条目(前者或后者)。
This site建议您使用的类,您只需实现IEqualityComparer接口。