java 两个List集合各种情况对比处理
Lambda作为函数式编程中的基础部分,在其他编程语言(例如:Scala)中早就广为使用,但在JAVA领域中发展较慢,直到java8,才开始支持Lambda。
抛开数学定义不看,直接来认识Lambda。Lambda表达式本质上是匿名方法,其底层还是通过invokedynamic指令来生成匿名类来实现。它提供了更为简单的语法和写作方式,允许你通过表达式来代替函数式接口。在一些人看来,Lambda就是可以让你的代码变得更简洁,完全可以不使用——这种看法当然没问题,但重要的是lambda为Java带来了闭包。得益于Lamdba对集合的支持,通过Lambda在多核处理器条件下对集合遍历时的性能提高极大,另外我们可以以数据流的方式处理集合——这是非常有吸引力的。
1. List去重:
/**
* java List Strasm去重
* @param args
*/
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("1");
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("3");
list.add("4");
System.out.println("List去重前:" + list); list = list.stream().distinct().collect(Collectors.toList());
System.out.println("List去重后:" + list);
}
测试结果:

2. List根据对象某个字段去重:
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors; /**
* <p>测试user<p>
* @version 1.0
* @author li_hao
* @date 2018年7月18日
*/
public class User { private String userid;
private String username; public User(String userid, String username) {
super();
this.userid = userid;
this.username = username;
} public String getUserid() {
return userid;
}
public void setUserid(String userid) {
this.userid = userid;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
} @Override
public String toString() {
return "User [userid=" + userid + ", username=" + username + "]";
} /**
* list Stream根据对象userid字段去重
*/
public static void main(String[] args) {
List<User> list = new ArrayList<User>();
list.add(new User("1","张三"));
list.add(new User("1","zhangsan"));
list.add(new User("2","李四"));
list.add(new User("2","李四"));
list.add(new User("3","刘大壮")); System.out.println("根据userid去重前:" + list); List<User> listRmdup = new ArrayList<User>();
list.stream()
.collect(Collectors.groupingBy(User :: getUserid)) //把list中数据根据userid分组
.forEach((String userid, List<User> ls) -> { //遍历分组
listRmdup.add(ls.get(0)); //取分组中的首个userid的对象存入新的listlistRmdup中
}); // 分开写
// Map<String, List<User>> collect = list.stream().collect(Collectors.groupingBy(User :: getUserid)); //把list中数据根据userid分组
// collect.forEach((String userid, List<User> ls) -> { //遍历分组
// listRmdup.add(ls.get(0)); //取分组中的首个userid的对象存入新的listlistRmdup中
// }); System.out.println("根据userid去重后:" + listRmdup);
} }
测试结果:
根据userid去重前:[User [userid=1, username=张三], User [userid=1, username=zhangsan], User [userid=2, username=李四], User [userid=2, username=李四], User [userid=3, username=刘大壮]]
根据userid去重后:[User [userid=1, username=张三], User [userid=2, username=李四], User [userid=3, username=刘大壮]]
3. 对比两个List,返回两个list中:合并后集合、合并去重后的集合、相同的集合、不同的集合、list1中不在list2中的集合、list2不在list1中的集合:
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors; public class TestStream { /**
* 对比两个list,返回两个list中:合并后集合、合并去重后的集合、相同的集合、不同的集合、list1中不在list2中的集合、list2不在list1中的集合
* @param list1 集合1
* @param list2 集合2
* @param cmpType 比较类型返回:a:合并后集合;b:合并去重后的集合;c:相同的集合;d:不同的集合;e:list1中不在list2中的集合;f:list2不在list1中的集合;
* @return List 返回处理后的集合
* 例如:
* list1 :[1, 2, 3, 3, 4, 5, 6]
* list2 :[3, 4, 4, 7, 8]
* a:合并后集合,listAll:[1, 2, 3, 3, 4, 5, 6, 3, 4, 4, 7, 8]
* b:合并去重后的集合;[1, 2, 3, 4, 5, 6, 7, 8]
* c:相同的集合;[3, 4]
* d:不同的集合;[1, 2, 5, 6, 7, 8]
* e:list1中不在list2中的集合;[1, 2, 5, 6]
* f:list2不在list1中的集合;[7, 8]
*/
public static List<String> compareList(List<String> list1, List<String> list2, String cmpType){
List<String> retList = new ArrayList<String>();
List<String> listAll = new ArrayList<String>(); listAll.addAll(list1);
listAll.addAll(list2); if("a".equals(cmpType)){
//合并后的集合
retList = listAll;
}
if("b".equals(cmpType)){
//合并去重后的集合
retList = listAll.stream().distinct().collect(Collectors.toList());
}
if("c".equals(cmpType) || "d".equals(cmpType) || "e".equals(cmpType) || "f".equals(cmpType)){
//相同的集合
List<String> listSameTemp = new ArrayList<String>();
list1.stream().forEach(a -> {
if(list2.contains(a))
listSameTemp.add(a);
});
retList = listSameTemp.stream().distinct().collect(Collectors.toList()); //不同的集合
if("d".equals(cmpType)){
List<String> listTemp = new ArrayList<>(listAll);
listTemp.removeAll(retList);
retList = listTemp;
}
//list1中不在list2中的集合
if("e".equals(cmpType)){
List<String> listTemp = new ArrayList<>(list1);
listTemp.removeAll(retList);
retList = listTemp;
}
//list2中不在list1中的集合
if("f".equals(cmpType)){
List<String> listTemp = new ArrayList<>(list2);
listTemp.removeAll(retList);
retList = listTemp;
}
}
return retList;
} /**
* 测试
*/
public static void main(String[] args) {
List<String> list1 = new ArrayList<String>();
list1.add(new String("1"));
list1.add(new String("2"));
list1.add(new String("3"));
list1.add(new String("3"));
list1.add(new String("4"));
list1.add(new String("5"));
list1.add(new String("6")); List<String> list2 = new ArrayList<String>();
list2.add(new String("3"));
list2.add(new String("4"));
list2.add(new String("4"));
list2.add(new String("7"));
list2.add(new String("8")); System.out.println("list1:" + list1);
System.out.println("list2:" + list2);
System.out.println("合并后集合:" + compareList(list1, list2, "a"));
System.out.println("合并去重后的集合:" + compareList(list1, list2, "b"));
System.out.println("相同的集合:" + compareList(list1, list2, "c"));
System.out.println("不同的集合:" + compareList(list1, list2, "d"));
System.out.println("list1中不在list2中的集合:" + compareList(list1, list2, "e"));
System.out.println("list2中不在list1中的集合:" + compareList(list1, list2, "f")); }
}
测试结果:

4. 从一个对象集合中获取每个对象的某个值返回一个新的集合:
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors; /**
* <p>测试user<p>
* @version 1.0
* @author li_hao
* @date 2018年7月18日
*/
public class User { private String userid;
private String username; public User(String userid, String username) {
super();
this.userid = userid;
this.username = username;
} public String getUserid() {
return userid;
}
public void setUserid(String userid) {
this.userid = userid;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
} @Override
public String toString() {
return "User [userid=" + userid + ", username=" + username + "]";
} /**
* 从一个对象集合中获取每个对象的某个值返回一个新的集合
*/
public static void main(String[] args) {
List<User> list = new ArrayList<User>();
list.add(new User("1","张三"));
list.add(new User("2","李四"));
list.add(new User("3","刘大壮")); System.out.println("处理前:" + list); List<String> Useridlist = list.stream().map(User :: getUserid).collect(Collectors.toList()); System.out.println("处理后:" + Useridlist);
} }
测试结果:

java 两个List集合各种情况对比处理的更多相关文章
- [转] Java程序员学C#基本语法两个小时搞定(对比学习)
Java程序员学C#基本语法两个小时搞定(对比学习) 对于学习一门新的语言,关键是学习新语言和以前掌握的语言的区别,但是也不要让以前语言的东西,固定了自己的思维模式,多看一下新的语言的编程思想. ...
- 【java】【反射】反射实现判断发生了修改操作,判断两个对象是否发生属性值的变更,判断两个List集合内对象的属性值是否发生变更
java的反射实现: 判断发生了修改操作,判断两个对象是否发生属性值的变更,判断两个List集合内对象的属性值是否发生变更 今日份代码: package com.sxd.streamTest; imp ...
- Java多线程系列--“JUC集合”04之 ConcurrentHashMap
概要 本章是JUC系列的ConcurrentHashMap篇.内容包括:ConcurrentHashMap介绍ConcurrentHashMap原理和数据结构ConcurrentHashMap函数列表 ...
- Java多线程系列--“JUC集合”05之 ConcurrentSkipListMap
概要 本章对Java.util.concurrent包中的ConcurrentSkipListMap类进行详细的介绍.内容包括:ConcurrentSkipListMap介绍ConcurrentSki ...
- Java中如何克隆集合——ArrayList和HashSet深拷贝
编程人员经常误用各个集合类提供的拷贝构造函数作为克隆List,Set,ArrayList,HashSet或者其他集合实现的方法.需要记住的是,Java集合的拷贝构造函数只提供浅拷贝而不是深拷贝,这意味 ...
- Java多线程系列--“JUC集合”02之 CopyOnWriteArrayList
概要 本章是"JUC系列"的CopyOnWriteArrayList篇.接下来,会先对CopyOnWriteArrayList进行基本介绍,然后再说明它的原理,接着通过代码去分析, ...
- Java多线程系列--“JUC集合”03之 CopyOnWriteArraySet
概要 本章是JUC系列中的CopyOnWriteArraySet篇.接下来,会先对CopyOnWriteArraySet进行基本介绍,然后再说明它的原理,接着通过代码去分析,最后通过示例更进一步的了解 ...
- Java多线程系列--“JUC集合”07之 ArrayBlockingQueue
概要 本章对Java.util.concurrent包中的ArrayBlockingQueue类进行详细的介绍.内容包括:ArrayBlockingQueue介绍ArrayBlockingQueue原 ...
- Java多线程系列--“JUC集合”08之 LinkedBlockingQueue
概要 本章介绍JUC包中的LinkedBlockingQueue.内容包括:LinkedBlockingQueue介绍LinkedBlockingQueue原理和数据结构LinkedBlockingQ ...
随机推荐
- pip改源
临时 python -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple django==1.10 # ==后边指定版本号,也可以不指定 ...
- SX_WIN10X64LTSB2016_EN_LITE英文精简版
SX_WIN10X64LTSB2016_EN_LITE英文精简版该版本为英文版!该版本为英文版!该版本为英文版!因为论坛巴基斯坦的maanu兄弟PM我,所以抽空做了一个.介绍沿用原来的,中文用谷歌翻译 ...
- storm中的一些概念
1.topology 一个topolgy是spouts和bolts组成的图,通过stream groupings将图中的spout和bolts连接起来:如图所示: 一个topology会一直运行知道你 ...
- 20164310Exp1 PC平台逆向破解和BOF基础
1.逆向及Bof基础实践说明 1.1实践目标 实践对象:pwn1的linux可执行文件 实践目的:使程序执行另一个代码(ShellCode) 实践内容: 手工修改可执行文件,改变程序执行 ...
- Linux安装/升级pip
Linux安装/升级pip 1.执行脚本 # wget https://bootstrap.pypa.io/get-pip.py # 如果没有 wget,先安装 wget # yum -y insta ...
- Centos 7环境下安装配置MySQL 5.7
安装步骤为: 1.由于Centos 7版中已经移除MySQL rpm,因此需要到其官方网站上下载rpm,下载完成后,使用以下命令,来安装MySQL的rpm配置. rpm -ivh *****[注释:* ...
- net start mysql意外终止1607
以下个人见解,错了请指出,谢谢 问题:安装了mysql,看到别人都用net start mysql来启动mysql服务,结果我打开cmd,用net start mysql 就会出问题.在网上查资料,好 ...
- 关于如何使用ehcarts2加载svg矢量地图并自定义县级内部乡镇轮廓
项目需求:显示县级内部的乡镇一级地图的轮廓! 效果预览: 阻碍因素:echarts不提供县级以下乡镇级轮廓. 解决思路: 1.根据资料查找相关县的行政区域图(百度搜索),如本人所制作的浙江省宁波市宁海 ...
- Python for循环之图像练习
矩形 # 控制行 for i in range(1,5): # 控制列 for j in range(1,8): # 用end在末尾传入空格串,这样print函数就不会自动换行了 print('*', ...
- Django基础模板层(75-76)
Django框架之模板层(d75)一 模版语法之变量: ** locals() 会把*该*视图函数内的变量,传到模板 ** return render(request, 'index.html' ...