java高并发之ArrayBlockingQueue的那些事
注意:本文内容基于JDK11,不同版本会有差异
1|0数据结构
queue本质上的数据结构还是一个数组。items就是queue中用来存放数据的数组。
2|0源码解析
本文以put/add/offer三个加入元素的方法为入口,来解析ArrayBlockingQueue的底层逻辑。
代码中的enqueuq是元素的入列的具体实现。它本质上的逻辑就是往数组中添加元素
2|1put方法
put方法会在队列已满的情况下进入线程阻塞。它的高并发是通过可重入锁ReentrantLock来保证线程安全的。
2|2add方法
add方法通过调用父类的add方法。在父类中,add方法则是通过调用对应的offer方法来进行实现的。所以add的最终实现方法还是offer。add方法和offer方法的区别在于如果队列满了,add方法会抛出异常,而offer方法只返回true或者false。
2|3offer方法
__EOF__
本文作者:飞翔的鲸
本文链接:https://www.cnblogs.com/whaletail/p/16062993.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/whaletail/p/16062993.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~