开发难免需要对集合进行操作,例如对两个集合取交集也是常见操作。下面就列举了几种对两个集合取交集的方法。
方式1:利用java8 stream流
list<integer> list1 = arrays.aslist(1, 2, 3, 4, 5);
list<integer> list2 = arrays.aslist(4, 5, 6, 7, 8);
list<integer> intersection = list1.stream()
.filter(list2::contains)
.collect(collectors.tolist());
方式2:使用java的retainall()方法
list<integer> list1 = new arraylist<>(arrays.aslist(1, 2, 3, 4, 5));
list<integer> list2 = new arraylist<>(arrays.aslist(4, 5, 6, 7, 8));
// 创建list1的副本以避免修改原始集合
list<integer> copyoflist1 = new arraylist<>(list1);
copyoflist1.retainall(list2);
list<integer> intersection = copyoflist1;
注意:retainall()会改变原集合,所以通常需要先复制其中一个集合
方式3:使用apache commons collections
如果你的项目引入了apache commons collections库,你可以使用collectionutils.intersection()方法:
list<integer> list1 = new arraylist<>(arrays.aslist(1, 2, 3, 4, 5));
list<integer> list2 = new arraylist<>(arrays.aslist(4, 5, 6, 7, 8));
list<integer> intersection = collectionutils.intersection(list1, list2);
方式4:使用java 8的并行流(parallel streams)
对于大数据量,可以利用并行流提高性能
list<integer> list1 = ...;
list<integer> list2 = ...;
list<integer> intersection = list1.parallelstream()
.filter(list2::contains)
.collect(collectors.tolist());
注意:并行流可以利用多核处理器的优势,但是,如果集合大小较小,可能并不会带来显著的性能提升,反而会增加不必要的线程开销。
有更好的方式或想法,欢迎大家评论区留言,互相学习~
发表评论