List<Object>去重
来源:互联网 发布:重庆知秋凤凰怎么样 编辑:程序博客网 时间:2024/05/19 06:16
先了解TreeSet
TreeSet 是一个有序的集合,它的作用是提供有序的Set集合。它继承于AbstractSet抽象类,实现了NavigableSet<E>, Cloneable, java.io.Serializable接口。
TreeSet 继承于AbstractSet,所以它是一个Set集合,具有Set的属性和方法。
TreeSet 实现了NavigableSet接口,意味着它支持一系列的导航方法。比如查找与指定目标最匹配项。
TreeSet 实现了Cloneable接口,意味着它能被克隆。
TreeSet 实现了java.io.Serializable接口,意味着它支持序列化。
TreeSet是基于TreeMap实现的。TreeSet中的元素支持2种排序方式:自然排序 或者 根据创建TreeSet 时提供的 Comparator 进行排序。这取决于使用的构造方法
TreeSet为基本操作(add、remove 和 contains)提供受保证的 log(n) 时间开销。
另外,TreeSet是非同步的。 它的iterator 方法返回的迭代器是fail-fast的。
第一种方式:使用treeSet的特性加上匿名类(lambda 表达式 ->)去重
public static void main(String[] args) {
Demodemo = new Demo();
demo.setName("张");
demo.setAge("20");
Demodemo2 = new Demo();
demo2.setName("张");
demo2.setAge("20");
Demodemo3 = new Demo();
demo3.setName("张");
demo3.setAge("20");
Demodemo4 = new Demo();
demo4.setName("张");
demo4.setAge("20");
Demodemo5 = new Demo();
demo5.setName("张1");
demo5.setAge("201");
List<Demo> list = Arrays.asList(demo1,demo2.demo3.demo4.demo5);
List<Demo> removeDupliById = removeDupliById(list);
System.out.println(removeDupliById);
Set<Demo> personSet = new TreeSet<>((o1, o2) -> o1.getAge().compareTo(o2.getAge()));
personSet.addAll(persons);
return new ArrayList<>(personSet);
}
第二种方式:重写equals()和hashcode()方法--》使用hashSet的特性进行去重
Demo z1= new Demo();
z1.setId("1001");
z1.setName("测试 1");
Demo z2 = new Demo();
z2.setId("1001");
z2.setName("测试 1");
Demo z3 = new Demo();
z3.setId("1002");
z3.setName("测试 1");
Demo z4 = new Demo();
z4.setId("1002");
z4.setName("测试 1");
Demo z5 = new Demo();
z5.setId("1003");
z5.setName("测试 1");
List<Demo> list = Arrays.asList(z1 ,z2 .z3 .z1 .z1 );
HashSet<Demo> deme= new HashSet<>();
deme.addAll(it);
TreeSet 是一个有序的集合,它的作用是提供有序的Set集合。它继承于AbstractSet抽象类,实现了NavigableSet<E>, Cloneable, java.io.Serializable接口。
TreeSet 继承于AbstractSet,所以它是一个Set集合,具有Set的属性和方法。
TreeSet 实现了NavigableSet接口,意味着它支持一系列的导航方法。比如查找与指定目标最匹配项。
TreeSet 实现了Cloneable接口,意味着它能被克隆。
TreeSet 实现了java.io.Serializable接口,意味着它支持序列化。
TreeSet是基于TreeMap实现的。TreeSet中的元素支持2种排序方式:自然排序 或者 根据创建TreeSet 时提供的 Comparator 进行排序。这取决于使用的构造方法
TreeSet为基本操作(add、remove 和 contains)提供受保证的 log(n) 时间开销。
另外,TreeSet是非同步的。 它的iterator 方法返回的迭代器是fail-fast的。
第一种方式:使用treeSet的特性加上匿名类(lambda 表达式 ->)去重
public static void main(String[] args) {
Demodemo = new Demo();
demo.setName("张");
demo.setAge("20");
Demodemo2 = new Demo();
demo2.setName("张");
demo2.setAge("20");
Demodemo3 = new Demo();
demo3.setName("张");
demo3.setAge("20");
Demodemo4 = new Demo();
demo4.setName("张");
demo4.setAge("20");
Demodemo5 = new Demo();
demo5.setName("张1");
demo5.setAge("201");
List<Demo> list = Arrays.asList(demo1,demo2.demo3.demo4.demo5);
List<Demo> removeDupliById = removeDupliById(list);
System.out.println(removeDupliById);
}
Set<Demo> personSet = new TreeSet<>((o1, o2) -> o1.getAge().compareTo(o2.getAge()));
personSet.addAll(persons);
return new ArrayList<>(personSet);
}
第二种方式:重写equals()和hashcode()方法--》使用hashSet的特性进行去重
Demo z1= new Demo();
z1.setId("1001");
z1.setName("测试 1");
Demo z2 = new Demo();
z2.setId("1001");
z2.setName("测试 1");
Demo z3 = new Demo();
z3.setId("1002");
z3.setName("测试 1");
Demo z4 = new Demo();
z4.setId("1002");
z4.setName("测试 1");
Demo z5 = new Demo();
z5.setId("1003");
z5.setName("测试 1");
List<Demo> list = Arrays.asList(z1 ,z2 .z3 .z1 .z1 );
HashSet<Demo> deme= new HashSet<>();
deme.addAll(it);
System.out.println("去重前 = [" + it + "]\n去重后"+deme);
阅读全文
0 0
- List<Object>去重
- list<map<String ,object>> 去重,list map去重
- List<Map<String,Object>>去重,排序
- List<Map<String,Object>>去重,排序
- python list去重
- List去重
- C# List去重
- list集合去重
- list 去重
- List去重
- List<对象>去重
- list去重排序
- python list 去重
- List<对象>去重
- Python list去重
- List集合去重
- List去重
- List排序去重
- oracle数据库初学
- 判断EditText字体超出限制,或者为空并提示
- 基于hibernate的BaseDAO接口
- Tango API 之四 --什么是Tango pose
- liunx多线程
- List<Object>去重
- 学习AIDL,这一篇差不多了
- 2016ACM-ICPC Regional Dalian
- oracle中的exists 和not exists 用法
- http java实现
- Android自定义炫酷进度条(闪电能量条)
- centos7 yum安装redis
- css 选择器
- SqlServer 等值连接,左连接,右连接