给定两个类
class Contract
{
public int ID {get; set;}
// . . .
}
class DBContract
{
public int FromID {get; set;}
// . . .
}
和两个IEnumerables
IEnumerable<Contract> ValidContracts = Application.GetContracts(//. . .
IEnumerable<DBContract> ExportedContracts = DBAdapter.GetRows(// . . .
我需要找到这些IEnumerables的交集。但是,如果IEqualityComparer只有一个类型参数,我该如何实现呢?
最佳答案
为什么不改用Where
和Any
?它的性能不如Intersect
,但它允许您过滤所需的方式:
var list = ExportedContracts.Where(ec => ValidContracts.Any(vc => vc.ID == ec.FromID));
您不能在此处使用
IEqualityComparer
,因为该对象没有任何接口(interface)或基类(object
除外)。关于c# - IEqualityComparer在不同类型上,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43973852/