java list去重方式,以及效率问题
之前面试被问到关于java如何去重的问题,当时没怎么留意,今天刚好项目中用到了,所以记录一下。
实体类:
/**
* 用户类
*/
class User{
private String username;
private String password; public User(String username, String password) {
this.username = username;
this.password = password;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
}
}
测试类:
public static void main(String[] args) {
ArrayList<User> arrayList = new ArrayList<>();
long currentTimeMillis = System.currentTimeMillis();
int f = 100000;
for(int i = 0; i < f; i++){
arrayList.add(new User(""+i, "7878"));
}
Iterator<User> iterator = arrayList.iterator();
Set<String> hashSet = new HashSet<>();
LinkedList<User> newList = new LinkedList<>();
// 第一种:set集合去重,不改变原有的顺序,根据username唯一标识去重
while (iterator.hasNext()){
User u = iterator.next();
// 根据set不能存放相同值的特性
if(!StringUtils.isEmpty(u.getUsername())){
if (hashSet.add(u.getUsername())){
// 将其重新放入在LinkedList中
newList.add(u);
}
}
}
long currentTimeMillis1_1 = System.currentTimeMillis();
System.out.println("第一种set集合去重,不改变原有的顺序:"+(currentTimeMillis1_1 - currentTimeMillis));
// 第二种:遍历后判断赋给另一个list集合,利用List的contains方法循环遍历
List<User> listNew=new ArrayList<>();
for (User str:arrayList) {
if(!listNew.contains(str)){
listNew.add(str);
}
}
long currentTimeMillis1_2 = System.currentTimeMillis();
System.out.println("第二种:遍历后判断赋给另一个list集合,利用List的contains方法循环遍历:"+(currentTimeMillis1_2 - currentTimeMillis1_1));
// 第三种:set去重
Set set = new HashSet();
List<String> listNew2=new ArrayList<>();
set.addAll(arrayList);
listNew2.addAll(set);
long currentTimeMillis1_3 = System.currentTimeMillis();
System.out.println(" 第三种:set去重"+(currentTimeMillis1_3 - currentTimeMillis1_2));
// 第四种:set去重(缩减为一行)
List<String> listNew3=new ArrayList<>(new HashSet(arrayList));
long currentTimeMillis1_4 = System.currentTimeMillis();
System.out.println("第四种:set去重(缩减为一行)"+(currentTimeMillis1_4 - currentTimeMillis1_3));
// 第五种:去重并按自然顺序排序
/* TreeSet treeSet = new TreeSet(arrayList);
List tempList = new ArrayList();
tempList.addAll(treeSet);
//List<User> listNew4=new ArrayList<>(new TreeSet<User>(arrayList));
long currentTimeMillis1_5 = System.currentTimeMillis();
System.out.println(currentTimeMillis1_5 - currentTimeMillis1_4);*/
// 第六种:双重for循环,去重
for(int i = 0 ; i < arrayList.size() - 1; i ++){
for(int j = arrayList.size() - 1; j > i; j --){
if(arrayList.get(j).equals(arrayList.get(i))){
arrayList.remove(j);
}
}
}
long currentTimeMillis1_6 = System.currentTimeMillis();
System.out.println("第六种:双重for循环,去重"+(currentTimeMillis1_6 - currentTimeMillis1_4));
// 第七种:利用HashSet不能添加重复数据的特性 由于HashSet不能保证添加顺序,所以只能作为判断条件
HashSet<User> set2 = new HashSet<>(arrayList.size());
List<User> result = new ArrayList<>(arrayList.size());
for (User str3 : arrayList) {
if (set2.add(str3)) {
result.add(str3);
}
}
arrayList.clear();
arrayList.addAll(result);
long currentTimeMillis1_7 = System.currentTimeMillis();
System.out.println("第七种:利用HashSet不能添加重复数据的特性 由于HashSet不能保证添加顺序,所以只能作为判断条件"+(currentTimeMillis1_7 - currentTimeMillis1_6));
// 第八种:利用LinkedHashSet不能添加重复数据并能保证添加顺序的特性
LinkedHashSet<User> set5 = new LinkedHashSet<>(arrayList.size());
set5.addAll(arrayList);
arrayList.clear();
arrayList.addAll(set5);
long currentTimeMillis1_8 = System.currentTimeMillis();
System.out.println("第八种:利用LinkedHashSet不能添加重复数据并能保证添加顺序的特性"+(currentTimeMillis1_8 - currentTimeMillis1_7));
}
控制台输出:

提示:在数据量大的情况下,最好不要使用第二种和第六种,速度太慢了
至于效率问题大家自己根据实际情况选择吧。
java list去重方式,以及效率问题的更多相关文章
- java List 去重方式及效率对比
01 实现思路:使用两个for循环遍历集合所有元素,然后进行判断是否有相同元素,如果有,则去除.这种方式是大部分最先想到的,也是最简单的实现方式.其中,这种方式可以保证List集合原来的顺序不变. 代 ...
- java List去重方式及效率对比
对List去重并保证添加顺序主要有三种方式: 方式一,利用HashSet不能添加重复数据的特性 由于HashSet不能保证添加顺序,所以只能作为判断条件: private static void re ...
- List集合去重方式及效率对比
List集合相信大家在开发过程中几乎都会用到.有时候难免会遇到集合里的数据是重复的,需要进行去除.然而,去重方式有好几种方式,你用的是哪种方式呢?去重方式效率是否是最高效.最优的呢?今天就给大家讲解一 ...
- java map遍历方式及效率
本文转载自Java Map遍历方式的选择. 只给出遍历方式及结论.测试数据可以去原文看. 如果你使用HashMap 同时遍历key和value时,keySet与entrySet方法的性能差异取决于ke ...
- java list 去重
Guava ImmutableSet源码去重处理,Hash处理 - 汪小哥 - CSDN博客 https://blog.csdn.net/u012881904/article/details/6895 ...
- java list去重操作实现方式
Java中的List是可以包含重复元素的(hash code 和equals),接下来将介绍两种方式实现java list去重操作,感兴趣的朋友可以参考下 Java中的List是可以包含重复元素的 ...
- java中多种写文件方式的效率对比实验
一.实验背景 最近在考虑一个问题:“如果快速地向文件中写入数据”,java提供了多种文件写入的方式,效率上各有异同,基本上可以分为如下三大类:字节流输出.字符流输出.内存文件映射输出.前两种又可以分为 ...
- java int转String全部方式的效率对照与深入解析
在java中,大家肯定都会遇到int类型转String类型的情形,知其然知其所以然.总结加分析一下,int类型转String类型有下面几种方式: a+"" String.value ...
- java多种文件复制方式以及效率比较
1.背景 java复制文件的方式其实有很多种,可以分为 传统的字节流读写复制FileInputStream,FileOutputStream,BufferedInputStream,BufferedO ...
随机推荐
- Python的入门(day1)
一:Python的起源 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,做为ABC 语言的一种 ...
- node项目自动化部署--基于Jenkins,Docker,Github(2)配置节点
上一篇文章中准备工作已经完成的差不多了 这一篇主要讲解 Jenkins 上面的相关配置 为了让代码部署到所有的子节点上 所以我们首先需要在 Jenkins 中添加我们希望代码部署到的节点 配置节点 首 ...
- java集群技术(转)
序言 越来越多的关键应用运行在J2EE(Java 2, Enterprise Edition)中,这些诸如银行系统和账单处理系统需要高的可用性(High Availability, HA),同时像Go ...
- Thymeleaf模板中变量报红
在上顶部添加 <!--suppress ThymeleafVariablesResolveInspection --> 或者 <!--suppress ALL --> 都可以解 ...
- MQ的用途与对比
RabbitMQ系列第一课:RabbitMQ安装 RabbitMQ系列第二课:RabbitMQ的原理介绍 RabbitMQ系列第三课:MQ用途与产品对比 一.MQ的用途:解耦和流量肖锋 二.常用MQ ...
- Berland Army CodeForces - 883B (贪心,拓扑排序)
大意: n个点, 点$i$的等级为$r_i$, 只给出部分点的$r$值, $r_i$的范围为[1,k], 且[1,k]都至少有一个. 给定m条有向边, (x,y)表示$r[x]>r[y]$, 求 ...
- 9.jQuery之简洁版滑动下拉菜单
知识点:hover的使用,已经slideToggle的切换效果 <style> * { margin: 0; padding: 0; } li { list-style-type: non ...
- Jade学习(二)之语法规则上
语法 ⚠️实例均结合node jade缩进代表层级 html <html></html> html <html> head <head> style & ...
- SpringBoot多数据源解决方案(转载)
1.开源项目地址:MyBatis Plus & Dynamic Datasource Maven配置: <dependency> <groupId>com.baomid ...
- Java的GUI框架如何选择? Swing、SWT、AWT、SwingX、JGoodies、JavaFX、Apache Pivot、BeautyEye框架(美观)?
AWT 是swing的基础,运行良好,但缺少高级组件.如果您打算创建丰富的应用程序,那么AWT可能不是最好的方法.但是对于不需要丰富用户界面的较小gui应用程序来说.这可能非常适合,因为它是一个久经考 ...