这篇文章给大家介绍Java中各种集合类的是怎样合并的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
集合类可谓是学习必知、编程必用、面试必会的,而且集合的操作十分重要;本文主要讲解如何合并集合类,如合并两个数组,合并两个List等。通过例子讲解几种不同的方法,有JDK原生的方法,还有使用第三库的方法。
引入十分常用的优秀的第三方库Guava
和Apache Commons
;通过配置pom.xml
如下:
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>28.1-jre</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-collections4</artifactId>
<version>4.4</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-exec</artifactId>
<version>1.3</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.5</version>
</dependency>
最新版本可以去官网搜索查看。
数据准备:
String[] arr1 = {"desk", "pen", "cup"};
String[] arr2 = {"phone", "keyboard"};
String[] expected = new String[]{"desk", "pen", "cup", "phone", "keyboard"};
String[] result;
JDK为我们提供了一个复制数组的方法,这个方法参数较多,使用不是很灵活,但它是一个本地方法,效率高。代码如下:
//System.arraycopy
result = new String[arr1.length + arr2.length];
System.arraycopy(arr1, 0, result, 0, arr1.length);
System.arraycopy(arr2, 0, result, arr1.length, arr2.length);
assertArrayEquals(expected, result);
Java 8的Stream
提供了转化成数组的方法,可以通过将数组转化成Stream
,合并Stream
后再转化为数组,具体代码如下:
//Stream
result = Stream.concat(Arrays.stream(arr1), Arrays.stream(arr2))
.toArray(String[]::new);
assertArrayEquals(expected, result);
使用的时候要注意Stream.toArray()
的两个方法,例子中需要使用带参数的。
Guava
提供了类ObjectArrays
进行数组合并,注意需要指定数组存储的对象的类型,代码如下:
//Guava
result = ObjectArrays.concat(arr1, arr2, String.class);
assertArrayEquals(expected, result);
Apache Commons
提供了ArrayUtils
进行合并,代码如下:
//Apache Commons
result = ArrayUtils.addAll(arr1, arr2);
assertArrayEquals(expected, result);
数据准备:
List<String> list1 = asList("desk", "pen", "cup");
List<String> list2 = asList("phone", "keyboard");
List<String> expected = asList("desk", "pen", "cup", "phone", "keyboard");
List<String> result = new ArrayList<>();
List
接口定义了addAll
的方法,代码如下:
//list.addAll
result.addAll(list1);
result.addAll(list2);
assertEquals(expected, result);
过程大体相似,合并Stream
,然后转化为List
,代码如下:
//Stream
result = Stream.concat(list1.stream(), list2.stream())
.collect(Collectors.toList());
assertEquals(expected, result);
Guava
提供了将Iterable
转化为List
的方法,代码如下:
//Guava
result = Lists.newArrayList(Iterables.concat(list1, list2));
assertEquals(expected, result);
Apache Commons
的工具类ListUtils
提供了union()
方法可以直接合并,代码如下:
//Apache Commons
result = ListUtils.union(list1, list2);
assertEquals(expected, result);
数据准备:
Set<String> set1 = Sets.newHashSet("desk", "pen", "cup", "phone", "keyboard");
Set<String> set2 = Sets.newHashSet("phone", "keyboard");
Set<String> expected = Sets.newHashSet("desk", "pen", "cup", "phone", "keyboard");
Set<String> result = Sets.newHashSet();
同样,Set
接口也有addAll()
方法,代码如下:
//set.addAll
result.addAll(set1);
result.addAll(set2);
assertEquals(expected, result);
先合并Stream
,再转化成Set
,代码如下:
//Stream
result = Stream.concat(set1.stream(), set2.stream())
.collect(Collectors.toSet());
assertEquals(expected, result);
一个方法搞定,代码如下:
//Guava
result = Sets.union(set1, set2);
assertEquals(expected, result);
同样是一个方法,代码如下:
//Apache Commons
result = SetUtils.union(set1, set2);
assertEquals(expected, result);
代码如下:
Map<String, Integer> map1 = ImmutableMap.of("One", 1, "Two", 2);
Map<String, Integer> map2 = ImmutableMap.of("Three", 3);
Map<String, Integer> expected = ImmutableMap.of("One", 1, "Two", 2, "Three", 3);
Map<String, Integer> result = Maps.newHashMap();
使用Map
接口提供的putAll()
方法,代码如下:
//map.putAll
result.putAll(map1);
result.putAll(map2);
assertEquals(expected, result);
使用Stream
进行合并Map
相对麻烦一些,代码如下:
//Stream
result = Stream.of(map1, map2)
.map(Map::entrySet)
.flatMap(Collection::stream)
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue));
assertEquals(expected, result);
使用builder()
方法,代码如下:
//Guava
result = ImmutableMap.<String, Integer>builder()
.putAll(map1)
.putAll(map2)
.build();
assertEquals(expected, result);
一个`merge()方法搞定,代码如下:
//Apache Commons
result = MapUtils.merge(map1, map2);
assertEquals(expected, result);
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4228891/blog/3122794