给定两个类

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只有一个类型参数,我该如何实现呢?

最佳答案

为什么不改用WhereAny?它的性能不如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/

10-15 13:27