Java中压缩集合,你都知道哪几种方式?

简介: 如果你不理解,我们可以看一个简单的例子,去说明什么是压缩集合。本文文章不长,但是还算是比较实用的小技巧。

案例解释什么是压缩集合


现在有两个集合:names和ages

List<String> names = new ArrayList<>(Arrays.asList("张三", "李四", "王五"));
List<Integer> ages = new ArrayList<>(Arrays.asList(24, 25, 27));

压缩完之后我们遍历压缩对象变成了下面这种形式:

张三:24
李四:25
王五:27

也就是name:age的键值对的形式,当然,如果我们的集合比较多,我们还可以压缩更多的集合。比如一个人的各种信息,id:name:age等等。


OK,知道了什么是压缩,下面不回长篇大论,直接给出压缩的几种形式,


压缩集合的几种方式


方式一:Java 8的IntStream

List<String> names = new ArrayList<>(Arrays.asList("张三", "李四", "王五"));
List<Integer> ages = new ArrayList<>(Arrays.asList(24, 25, 27));
//方式一:java8的IntSream
Stream<String> stream = IntStream
      .range(0, Math.min(names.size(), ages.size()))
      .mapToObj(i -> names.get(i) + ":" + ages.get(i));
//遍历输出
stream.forEach(System.out::println);

这种方式比较简单,获取两个集合的流,然后转化为对象。java8可以直接使用。


方式二:Guava Streams


List<String> names = new ArrayList<>(Arrays.asList("张三", "李四", "王五"));
List<Integer> ages = new ArrayList<>(Arrays.asList(24, 25, 27));
//方式二:guava
//第一种
Streams.forEachPair(
       Stream.of("张三", "李四", "王五"),
       Stream.of(1, 2,3),
       (name, age) -> System.out.println(name + ":" + age));
//第二种:
Stream<String> stream2 = Streams.zip(names.stream(), ages.stream(), 
        (name, age) -> name + ":" + age);
stream2.forEach(System.out::println);
//第三种:
Stream<String> stream3 = Streams.mapWithIndex(
        Stream.of("a", "b", "c"),
        (str, index) -> str + ":" + index);
stream3.forEach(System.out::println);

以上是几种实现的方式,这位大佬给出了一种,我又去官网找了其他几种。另外使用guava的时候,版本要求21以上。我们在pom文件添加以下依赖即可:

<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>30.1-jre</version>
 </dependency>

这里注意使用最新版的就可以。其他的也许会报错。我试了版本21的,也出错。


方式二:Using jOOλ(jOOL)


jOOL还在Java 8 Lambda上提供了一些有趣的新功能,并且通过对Tuple1到Tuple16的支持,zip操作变得更加有趣:

//方式三:jool
//第一种
Seq<Tuple2<String,Integer>> s1 = Seq.of("张三","李四", "王五")
    .zip(Seq.of(24,25,27));
//第二种
Seq<String> s2 = Seq.of(1, 2, 3)
    .zip(Seq.of("a", "b", "c"), (x, y) -> x + ":" + y);
//第三种
Seq<Tuple2<String,Long>> s3 = Seq.of("a", "b", "c").zipWithIndex();
s1.forEach(System.out::println);
s2.forEach(System.out::println);
s3.forEach(System.out::println);

Seq结果是一个压缩元组,我们可以看看。

(tuple(1, "a"), tuple(2, "b"), tuple(3, "c"))

这种方式也是需要添加依赖的。在pom文件添加如下依赖即可:

<dependency>
     <groupId>org.jooq</groupId>
     <artifactId>jool-java-8</artifactId>
     <version>0.9.14</version>
</dependency>

ok,还有很多,基本思想都是切成流,再合并。这个直接用java实现也可以。


结论


“zip”操作与标准的“concat”或“merge”稍有不同。“concat”或“merge”操作将简单地在现有集合的末尾添加新集合,而“zip”操作将从每个集合中获取一个元素并将它们组合起来。

相关文章
|
1月前
|
安全 Java 容器
【Java集合类面试二十七】、谈谈CopyOnWriteArrayList的原理
CopyOnWriteArrayList是一种线程安全的ArrayList,通过在写操作时复制新数组来保证线程安全,适用于读多写少的场景,但可能因内存占用和无法保证实时性而有性能问题。
|
1月前
|
存储 安全 Java
【Java集合类面试二十五】、有哪些线程安全的List?
线程安全的List包括Vector、Collections.SynchronizedList和CopyOnWriteArrayList,其中CopyOnWriteArrayList通过复制底层数组实现写操作,提供了最优的线程安全性能。
|
1月前
|
Java
【Java集合类面试二十八】、说一说TreeSet和HashSet的区别
HashSet基于哈希表实现,无序且可以有一个null元素;TreeSet基于红黑树实现,支持排序,不允许null元素。
|
1月前
|
Java
【Java集合类面试二十三】、List和Set有什么区别?
List和Set的主要区别在于List是一个有序且允许元素重复的集合,而Set是一个无序且元素不重复的集合。
|
1月前
|
Java
【Java集合类面试二十六】、介绍一下ArrayList的数据结构?
ArrayList是基于可动态扩展的数组实现的,支持快速随机访问,但在插入和删除操作时可能需要数组复制而性能较差。
|
1月前
|
存储 Java 索引
【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
ArrayList基于动态数组实现,支持快速随机访问;LinkedList基于双向链表实现,插入和删除操作更高效,但占用更多内存。
|
14天前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
|
3天前
|
存储 安全 Java
Java 常用集合分类
Java 常用集合分类
13 2
|
21天前
|
算法 Java
Java 压缩文件
在Java中压缩文件是一个常见的需求,通常可以通过使用Java自带的`java.util.zip`包来实现。这个包提供了`ZipOutputStream`类来创建ZIP格式的压缩文件。以下是一个简单的示例,展示了如何将多个文件压缩到一个ZIP文件中。 ### 示例:将多个文件压缩到一个ZIP文件中 ```java import java.io.*; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream; public class ZipFilesExample { public static vo
|
29天前
|
Java
用JAVA架建List集合为树形结构的代码方法
这段代码定义了一个表示树形结构的 `Node` 类和一个用于构建树形结构的 `TreeController`。`Node` 类包含基本属性如 `id`、`pid`、`name` 和 `type`,以及子节点列表 `children`。`TreeController` 包含初始化节点列表并将其转换为树形结构的方法。通过过滤和分组操作实现树形结构的构建。详情可见:[代码示例链接1](http://www.zidongmutanji.com/zsjx/43551.html),[代码效果参考链接2](https://www.257342.com/sitemap/post.html)。
31 5