C#中的复杂对象比较
发布时间:2020-12-15 19:33:58 所属栏目:百科 来源:网络整理
导读:参见英文答案 C# implementation of deep/recursive object comparison in .net 3.5????????????????????????????????????6个 我有两个相同类型的复杂对象.我想比较两个对象,以确定它们是否具有完全相同的值.这样做的有效方法是什么? 样本类结构如下: clas
参见英文答案 >
C# implementation of deep/recursive object comparison in .net 3.5????????????????????????????????????6个
我有两个相同类型的复杂对象.我想比较两个对象,以确定它们是否具有完全相同的值.这样做的有效方法是什么? 样本类结构如下: class Package { public List<GroupList> groupList; } class GroupList { public List<Feature> featurelist; } class Feature { public int qty; } 解决方法
好的,所以你想要深度无序的结构比较. “无序”部分很棘手,实际上它强烈暗示您的类设计不正确:List< T>本质上是有序的,所以也许您宁愿使用HashSet< T>那里(如果你不希望有任何重复).这样做会使比较更容易实现,并且更快(尽管插入会更慢):
class Package { public HashSet<GroupList> groupList; public override bool Equals(object o) { Package p = o as Package; if (p == null) return false; return groupList.SetEquals(p.groupList); } public override int GetHashCode() { return groupList.Aggregate(0,(hash,g) => hash ^ g.GetHashCode()); } } class GroupList { public HashSet<Feature> featureList; public override bool Equals(object o) { GroupList g = o as GroupList; if (g == null) return false; return featureList.SetEquals(g.featureList); } public override int GetHashCode() { return featureList.Aggregate(0,f) => hash ^ f.GetHashCode()); } } class Feature { public int qty; public override bool Equals(object o) { Feature f = o as Feature; if (f == null) return false; return qty == f.qty; } public override int GetHashCode() { return qty.GetHashCode(); } } 如果你想继续使用List< T>,你需要使用LINQ set操作 – 但请注意,这些操作要慢得多: class Package { public List<GroupList> groupList; public override bool Equals(object o) { Package p = o as Package; if (p == null) return false; return !groupList.Except(p.groupList).Any(); } } class GroupList { public List<Feature> featureList; public override bool Equals(object o) { GroupList g = o as GroupList; if (g == null) return false; return !featureList.Except(f.featureList).Any(); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |