【Java进阶营】聊聊Java里常用的并发集合

本文介绍了Java中四种并发集合:非阻塞的ConcurrentLinkedDeque、阻塞的LinkedBlockingDeque、优先级排序的PriorityBlockingQueue以及延迟元素的DelayQueue。详细阐述了它们的特点、常用方法以及使用场景,帮助开发者选择合适的并发集合工具。
摘要由CSDN通过智能技术生成

前言
在我们的程序开发过程中,如果涉及到多线程环境,那么对于集合框架的使用就必须更加谨慎了,因为大部分的集合类在不施加额外控制的情况下直接在并发环境中直接使用可能会出现数据不一致的问题,所以为了解决这个潜在的问题,我们要么在自己的业务逻辑中加上一些额外的控制,例如锁,或者我们直接使用Java提供的可在并发环境中使用的集合类,这是一个简便而且高效的方法。那么我们下面就来了解下Java提供了哪些“神器”可以让我们安全的使用集合。

正文
非阻塞式安全列表 - ConcurrentLinkedDeque
ConcurrentLinkedDeque可以在并发环境中直接使用,所谓的非阻塞,就是当列表为空的时候,我们还继续从列表中取数据的话,它会直接返回null或者抛出异常。下面列出来一些常用的方法。

peekFirst()、peekLast() :返回列表中首位跟末尾元素,如果列表为空则返回null。返回的元素不从列表中删除。
getFirst()、getLast() :返回列表中首位跟末尾元素,如果列表为空则抛出NoSuchElementExceotion异常。返回的元素不从列表中删除。
removeFirst()、removeLast() :返回列表中首位跟末尾元素,如果列表为空则抛出NoSuchElementExceotion异常。【返回的元素会从列表中删除】。
阻塞式安全列表 - LinkedBlockingDeque
LinkedBlockingDeque是一个阻塞式的线程安全列表,它跟 ConcurrentLinkedDeque最大的区别就是,当列表中元素满了或者为空的时候,我们对该列表的操作不会立即返回,而是阻塞当前操作,直到该操作可以执行时才返回。我们对比着上面ConcurrentLinkedDeque的常用方法,来看下Lin

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值