当根据对象的name属性进行去重时,你可以使用以下三种方法:使用distinct方法和自定义比较器、使用linq的groupby方法,以及使用hashset。下面是每种方法的详细代码示例和解释:
1.使用distinct方法和自定义比较器:
using system; using system.collections.generic; using system.linq; // 自定义对象类 public class person { public string name { get; set; } } // 自定义比较器类 public class nameequalitycomparer : iequalitycomparer<person> { public bool equals(person x, person y) { return x.name == y.name; } public int gethashcode(person obj) { return obj.name.gethashcode(); } } public class program { public static void main() { // 创建包含重复对象的集合 list<person> people = new list<person>() { new person { name = "john" }, new person { name = "jane" }, new person { name = "john" }, new person { name = "alice" }, new person { name = "jane" } }; // 使用distinct方法和自定义比较器进行去重 list<person> distinctpeople = people.distinct(new nameequalitycomparer()).tolist(); // 输出去重后的结果 foreach (person person in distinctpeople) { console.writeline(person.name); } } }
解释:
- 在上述代码中,我们首先定义了一个person类,具有name属性作为去重的依据。
- 然后,我们创建了一个包含重复对象的list<person>集合。
- 接下来,我们定义了一个名为nameequalitycomparer的自定义比较器类,实现了iequalitycomparer<person>接口。
- 在自定义比较器类中,我们重写了equals方法和gethashcode方法,分别根据person对象的name属性进行比较和哈希计算。
- 在主程序中,我们使用distinct方法,并将自定义比较器作为参数传递给该方法,以实现根据name属性进行去重的功能。
- 最后,我们将去重后的结果转换为list<person>类型,并逐个输出去重后的person对象的name属性。
2.使用linq的groupby方法:
using system; using system.collections.generic; using system.linq; // 自定义对象类 public class person { public string name { get; set; } } public class program { public static void main() { // 创建包含重复对象的集合 list<person> people = new list<person>() { new person { name = "john" }, new person { name = "jane" }, new person { name = "john" }, new person { name = "alice" }, new person { name = "jane" } }; // 使用groupby方法根据name属性进行分组,并选择每个分组的第一个对象 list<person> distinctpeople = people.groupby(p => p.name).select(g => g.first()).tolist(); // 输出去重后的结果 foreach (person person in distinctpeople) { console.writeline(person.name); } } }
解释:
- 在上述代码中,我们定义了一个person类,具有name属性作为去重的依据。
- 然后,我们创建了一个包含重复对象的list<person>集合。
- 接下来,我们使用groupby方法根据name属性进行分组。这将返回一个ienumerable<igrouping<string, person>>,其中每个分组具有一个键(name属性的值)和相应的对象集合。
- 然后,我们使用select方法选择每个分组的第一个对象,以实现去重的效果。
- 最后,我们将去重后的结果转换为list<person>类型,并逐个输出去重后的person对象的name属性。
3.使用hashset:
using system; using system.collections.generic; // 自定义对象类 public class person { public string name { get; set; } } public class program { public static void main() { // 创建包含重在c#中,你可以使用以下几种方法根据对象的name属性对集合进行去重: 1. 使用distinct方法和自定义比较器: ```csharp using system; using system.collections.generic; using system.linq; public class person { public string name { get; set; } } public class nameequalitycomparer : iequalitycomparer<person> { public bool equals(person x, person y) { return x.name == y.name; } public int gethashcode(person obj) { return obj.name.gethashcode(); } } public class program { public static void main() { list<person> people = new list<person>() { new person { name = "john" }, new person { name = "jane" }, new person { name = "john" }, new person { name = "alice" }, new person { name = "jane" } }; list<person> distinctpeople = people.distinct(new nameequalitycomparer()).tolist(); foreach (person person in distinctpeople) { console.writeline(person.name); } } }
在上面的代码中,我们定义了一个person类,其中包含一个name属性用于去重。然后,我们创建了一个包含重复对象的list集合。接下来,我们定义了一个nameequalitycomparer类,实现了iequalitycomparer接口,其中equals方法用于比较name属性是否相等,gethashcode方法用于获取name属性的哈希码。在主程序中,我们使用distinct方法,并将自定义的比较器作为参数传递给distinct方法,以实现根据name属性进行去重的功能。最后,我们将去重后的结果转换为list类型,并遍历输出每个人物的name属性。
4.使用linq的groupby方法:
using system; using system.collections.generic; using system.linq; public class person { public string name { get; set; } } public class program { public static void main() { list<person> people = new list<person>() { new person { name = "john" }, new person { name = "jane" }, new person { name = "john" }, new person { name = "alice" }, new person { name = "jane" } }; list<person> distinctpeople = people.groupby(p => p.name).select(g => g.first()).tolist(); foreach (person person in distinctpeople) { console.writeline(person.name); } } }
在上面的代码中,我们同样定义了一个person类,并创建了一个包含重复对象的list集合。然后,我们使用groupby方法根据name属性进行分组,将相同name属性的对象放入同一个组中。接着,我们使用select方法选择每个组中的第一个对象,以实现去重的效果。最后,我们将去重后的结果转换为list类型,并遍历输出每个人物的name属性。
5.使用hashset:
using system; using system.collections.generic; public class person { public string name { get; set; } } public class program { public static void main() { list<person> people = new list<person>() { new person { name = "john" }, new person { name = "jane" }, new person { name = "john" }, new person { name = "alice" }, new person { name = "jane" } }; hashset<person> distinctpeople = new hashset<person>(people, new nameequalitycomparer()); foreach (person person in distinctpeople) { console.writeline(person.name); } } }
在上面的代码中,我们同样定义了一个person类,并创建了一个包含重复对象的list集合。然后,我们使用hashset类,并将list集合和自定义的比较器传递给hashset的构造函数,以实现根据name属性进行去重的功能。最后,我们遍历输出去重后的结果。
到此这篇关于c#集合根据对象的某个属性进行去重的文章就介绍到这了,更多相关c#根据对象的某个属性去重内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论