前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Java 如何将 List 转换为 MAP

Java 如何将 List 转换为 MAP

原创
作者头像
HoneyMoose
发布于 2022-10-12 15:30:15
发布于 2022-10-12 15:30:15
2.2K00
代码可运行
举报
文章被收录于专栏:CWIKIUSCWIKIUS
运行总次数:0
代码可运行

有时候我们需要将给定的 List 转换为 Map。

如果你使用的是 Java 8 以后版本的话,Stream 是你的好朋友。

Java 8

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 public Map<Integer, Animal> convertListAfterJava8(List<Animal> list) {
    Map<Integer, Animal> map = list.stream()
      .collect(Collectors.toMap(Animal::getId, Function.identity()));
    return map;
}

上面的代码可以非常容易的完成转换,我们有一个 Animal 对象的 List。

上面的代码将会把 Id 作为 Key,然后生成的 Map 是以 id 为 Key,Animal 为Value 的 Map。

Guava

如果使用 Guava 就更加简单了。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public Map<Integer, Animal> convertListWithGuava(List<Animal> list) {
    Map<Integer, Animal> map = Maps
      .uniqueIndex(list, Animal::getId);
    return map;
}

使用 Maps 的工具类就可以了,这个工具类可以直接用。

更进一步

如果对需要生成的 Map 进行处理。

Key 是对象中的一个值,Value 是 List 对象中的另外一个值。

例如可以使用下面的代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
listingStatusList.stream().collect(Collectors.toMap(CListingStatus::getListingStatusKey, CListingStatus::getListingStatus));

其中 CListingStatus 对象是这样定义的。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Entity
@Getter
@Setter
public class CListingStatus extends AbstractPersistable<Long> {

    @ManyToOne
    @JoinColumn(name = "rets_id", nullable = false)
    private ConfRets confRets;

    private String listingStatusKey;

    private ListingStatus listingStatus ;

}

对 Map 中的对象设值

针对 Stream 中的对象,我们可能还需要重新设置为其他的对象。

这个时候我们就可以使用 lambda 函数了。

同样的代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        HashMap<String, Agent> agentHashMap = (HashMap) mlsAgentList.stream().collect(Collectors.toMap(MlsAgent::getMlsAgentId, mlsAgent -> {
            Agent agent = new Agent();
            agent.setAgentId(mlsAgent.getMlsAgentId());
            agent.setAgentNameFirst(mlsAgent.getNameFirst());
            agent.setAgentNameLast(mlsAgent.getNameLast());
            agent.setAgentEmail(mlsAgent.getEmail());
            return agent;
        }));

我们返回的 Map 使用了一个新的对象为 Value。

上面针对 Stream 转换为 Map 的方法进行了一些小总结,这些方法可能实际编程的时候使用的频率比较高。

同时能够避免大量使用 For 循环的情况。

Stream 还是需要好好了解下的。

https://www.ossez.com/t/java-list-map/14144

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
JAVA并发编程系列(3)JUC包之CAS原理
首先,Atomic包,原子操作类,提供了用法简单、性能高效、最重要是线程安全的更新一个变量。支持整型、长整型、布尔、double、数组、以及对象的属性原子修改,支持种类非常丰富。
拉丁解牛说技术
2024/09/06
1431
Java并发编程CAS
它的功能是判断内存某一个位置的值是否为预期,如果是则更改这个值,这个过程就是原子的。
一觉睡到小时候
2020/05/27
4770
java吧_死磕好不好
前面我们说到volatile不保证原子性,解决办法就是使用AtomicInteger代替int,但是为什么使用AtomicInteger就可以保证了原子性了,是因为AtomicInteger实现的就是CAS思想和Unsafe的支持。
全栈程序员站长
2022/08/04
7260
【死磕Java并发】—- 深入分析CAS
CAS,Compare And Swap,即比较并交换。Doug lea大神在同步组件中大量使用CAS技术鬼斧神工地实现了Java多线程的并发操作。整个AQS同步组件、Atomic原子类操作等等都是以
芋道源码
2018/03/01
7850
【死磕Java并发】—- 深入分析CAS
一篇搞定CAS,深度讲解,面试实践必备
在高并发的业务场景下,线程安全问题是必须考虑的,在JDK5之前,可以通过synchronized或Lock来保证同步,从而达到线程安全的目的。但synchronized或Lock方案属于互斥锁的方案,比较重量级,加锁、释放锁都会引起性能损耗问题。
程序新视界
2022/07/29
4210
一篇搞定CAS,深度讲解,面试实践必备
CAS 原理深入剖析,深入内核源码的那种
则先读取 A 的当前值 E 为 2,在内存计算结果 V 为 3,比较之前读出来的 A 的当前值 2 和 最新值,如果最新值为 2 ,表示这个值没有被别人改过,则放心的把最终的值更新为 3.
kk大数据
2021/03/13
1.1K0
【死磕Java并发】常用并发原子类详解
在 Java 的java.util.concurrent包中,除了提供底层锁、并发同步等工具类以外,还提供了一组原子操作类,大多以Atomic开头,他们位于java.util.concurrent.atomic包下。
Java极客技术
2023/12/14
3060
【死磕Java并发】常用并发原子类详解
Java并发——CAS(十)
在大多数处理器的指令中,都会实现 CAS 相关的指令,这一条指令就可以完成“比较并交换”的操作,也正是由于这是一条(而不是多条)CPU 指令,所以 CAS 相关的指令是具备原子性的,这个组合操作在执行期间不会被打断,这样就能保证并发安全。由于这个原子性是由 CPU 保证的,所以无需我们程序员来操心。
翰墨飘香
2024/05/21
2560
【java并发编程实战2】无锁编程CAS与atomic包1、无锁编程CAS2、 atomic族类
如果V值等于E值,则将V的值设为N。若V值和E值不同,则说明已经有其他线程做了更新,则当前线程什么都不做。通俗的理解就是CAS操作需要我们提供一个期望值,当期望值与当前线程的变量值相同时,说明还没线程修改该值,当前线程可以进行修改,也就是执行CAS操作,但如果期望值与当前线程不符,则说明该值已被其他线程修改,此时不执行更新操作,但可以选择重新读取该变量再尝试再次修改该变量,也可以放弃操作,原理图如下
yukong
2018/09/03
6470
【java并发编程实战2】无锁编程CAS与atomic包1、无锁编程CAS2、 atomic族类
Juc并发编程10——原子类与ABA问题解决方案
除了加锁以外,还可以使用原子类实现操作原子性。它底层采用CAS算法,使用简单、性能高效、线程安全。
半旧518
2022/10/26
3250
Juc并发编程10——原子类与ABA问题解决方案
【Java】CAS及其缺点和解决方案梳理
CAS 英文就是 compare and swap ,也就是比较并交换,首先它是一个原子操作,可以避免被其他线程打断。在Java并发中,最初接触的应该就是Synchronized关键字了,但是Synchronized属于重量级锁,很多时候会引起性能问题,虽然在新的 JDK 中对其已经进行了优化。volatile也是个不错的选择,但是volatile不能保证原子性,只能在某些场合下使用。那么问题来了,这个 CAS 机制是怎么在不加锁的情况下来保证共享资源的互斥呢?
后端码匠
2023/09/02
4510
【Java】CAS及其缺点和解决方案梳理
深入理解 CAS 及 ABA问题
本文 将通过AtomicInteger这个类,来分析是如何通过CAS来保证 Atomic的原子性的。
用户2141593
2019/02/20
8350
Java中CAS机制详解 - Java技术债务
传统的并发控制手段,如使用synchronized关键字或者ReentrantLock等互斥锁机制,虽然能够有效防止资源的竞争冲突,但也可能带来额外的性能开销,如上下文切换、锁竞争导致的线程阻塞等。而此时就出现了一种乐观锁的策略,以其非阻塞、轻量级的特点,在某些场合下能更好地提升并发性能,其中最为关键的技术便是Compare And Swap(简称CAS)。
Java技术债务
2024/06/21
1430
Java中CAS机制详解 - Java技术债务
CAS之比较并交换
compare and swap的缩写,中文翻译成比较并交换,实现并发算法时常用到的一种技术。它包含三个操作数——内存位置、预期原值及更新值。 执行CAS操作的时候,将内存位置的值与预期原值比较: 如果相匹配,那么处理器会自动将该位置值更新为新值, 如果不匹配,处理器不做任何操作,多个线程同时执行CAS操作只有一个会成功。
鱼找水需要时间
2023/02/16
4120
CAS之比较并交换
cas 原理分析
顾名思义,就是很悲观,假定会发生并发冲突,屏蔽一切可能违反数据完整性的操作,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁。
全栈程序员站长
2022/11/03
3620
cas 原理分析
Java并发编程之cas理论(无锁并发)
前面看到的AtomicInteger的解决方法,内部并没有用锁来保护共享变量的线程安全。那么它是如何实现的呢?
冬天vs不冷
2025/01/21
810
Java并发编程之cas理论(无锁并发)
CAS——比加锁更高效的多线程并发场景下数据一致性解决方案
cheese
2024/06/15
1250
CAS——比加锁更高效的多线程并发场景下数据一致性解决方案
【Java线程】线程安全三元素:原子性、可见性、有序性
首先大家需要思考一下何为线程安全性呢??? 《Java并发编程实战》书中给出定义:当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些线程将如何交替执行,并且在调用代码中不需要任何额外的同步,这个类都能表现出正确的行为,那么这个类就是线程安全的。
沁溪源
2021/03/22
4540
从JUC源码看CAS,我做了个笔记 ......
" JUC包下大量使用了CAS,工作和面试中也经常遇到CAS,包括说到乐观锁,也不可避免的想起CAS,那CAS究竟是什么? "
程序员小航
2020/11/23
3350
从JUC源码看CAS,我做了个笔记 ......
Java原子操作类,你知道多少?
由于synchronized是采用的是悲观锁策略,并不是特别高效的一种解决方案。 实际上,在J.U.C下的atomic包提供了一系列的操作简单,性能高效,并能保证线程安全的类去 更新基本类型变量,数组元素,引用类型以及更新对象中的字段类型。 atomic包下的这些类都是采用的是乐观锁策略去原子更新数据,在Java中则是使用CAS操作具体实现。
李红
2019/05/28
3950
推荐阅读
相关推荐
JAVA并发编程系列(3)JUC包之CAS原理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档