iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >java项目中实现CopyOnWriteArrayList并发容器的原理是什么
  • 509
分享到

java项目中实现CopyOnWriteArrayList并发容器的原理是什么

javacopyonwritearraylist并发容器 2023-05-31 13:05:15 509人浏览 泡泡鱼
摘要

今天就跟大家聊聊有关java项目中实现CopyOnWriteArrayList并发容器的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。CopyOnWriteArrayLis

今天就跟大家聊聊有关java项目中实现CopyOnWriteArrayList并发容器的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

CopyOnWriteArrayList是java并发包中提供的一个并发容器,它是个线程安全且读操作无的ArrayList,写操作则通过创建底层数组的新副本来实现,是一种读写分离的并发策略,我们也可以称这种容器为"写时复制器",Java并发包中类似的容器还有CopyOnWriteSet。本文会对CopyOnWriteArrayList的实现原理及源码进行分析。

实现原理

  我们都知道,集合框架中的ArrayList是非线程安全的,Vector虽是线程安全的,但由于简单粗暴的锁同步机制,性能较差。而CopyOnWriteArrayList则提供了另一种不同的并发处理策略(当然是针对特定的并发场景)。

  很多时候,我们的系统应对的都是读多写少的并发场景。CopyOnWriteArrayList容器允许并发读,读操作是无锁的,性能较高。至于写操作,比如向容器中添加一个元素,则首先将当前容器复制一份,然后在新副本上执行写操作,结束之后再将原容器的引用指向新容器。

java项目中实现CopyOnWriteArrayList并发容器的原理是什么

  优缺点分析

  了解了CopyOnWriteArrayList的实现原理,分析它的优缺点及使用场景就很容易了。

  优点:

  读操作性能很高,因为无需任何同步措施,比较适用于读多写少的并发场景。Java的list在遍历时,若中途有别的线程对list容器进行修改,则会抛出ConcurrentModificationException异常。而CopyOnWriteArrayList由于其"读写分离"的思想,遍历和修改操作分别作用在不同的list容器,所以在使用迭代器进行遍历时候,也就不会抛出ConcurrentModificationException异常了

  缺点:

  缺点也很明显,一是内存占用问题,毕竟每次执行写操作都要将原容器拷贝一份,数据量大时,对内存压力较大,可能会引起频繁GC;二是无法保证实时性,Vector对于读写操作均加锁同步,可以保证读和写的强一致性。而CopyOnWriteArrayList由于其实现策略的原因,写和读分别作用在新老不同容器上,在写操作执行过程中,读不会阻塞但读取到的却是老容器的数据。

源码分析

  基本原理了解了,CopyOnWriteArrayList的代码实现看起来就很容易理解了。

public boolean add(E e) {  //ReentrantLock加锁,保证线程安全  final ReentrantLock lock = this.lock;  lock.lock();  try {   Object[] elements = getArray();   int len = elements.length;   //拷贝原容器,长度为原容器长度加一   Object[] newElements = Arrays.copyOf(elements, len + 1);   //在新副本上执行添加操作   newElements[len] = e;   //将原容器引用指向新副本   setArray(newElements);   return true;  } finally {   //解锁   lock.unlock();  } } 

--结束END--

本文标题: java项目中实现CopyOnWriteArrayList并发容器的原理是什么

本文链接: https://www.lsjlt.com/news/226150.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java项目中实现CopyOnWriteArrayList并发容器的原理是什么
    今天就跟大家聊聊有关java项目中实现CopyOnWriteArrayList并发容器的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。CopyOnWriteArrayLis...
    99+
    2023-05-31
    java copyonwritearraylist 并发容器
  • Java中的ConcurrentSkipListMap:高性能并发容器的实现原理。
    Java中的ConcurrentSkipListMap:高性能并发容器的实现原理 在Java编程中,容器是一个非常重要的概念,它们可以存储和管理数据集合。随着多线程编程的普及,高性能并发容器也成为了Java编程的一个热门话题。其中,Conc...
    99+
    2023-09-19
    并发 数组 容器
  • Java并发编程中并发机制的底层实现原理是什么
    今天就跟大家聊聊有关Java并发编程中并发机制的底层实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java中的并发机制依赖于JVM的实现和CPU指令,接下来我们深入底层...
    99+
    2023-06-19
  • 在JAVA项目中组合模式的实现原理是什么
    今天就跟大家聊聊有关在JAVA项目中组合模式的实现原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。组合模式:将不同但是相关的对象组合成树形结构以实现“部分-整体”的层次结构,...
    99+
    2023-05-31
    java ava 组合模式
  • 什么是Java中的ConcurrentHashMap并发容器?
    Java中的ConcurrentHashMap是一种线程安全的并发容器,可以同时被多个线程访问和修改。它是一种高效的哈希表实现,可以在多线程环境下保证数据的一致性和可靠性。 ConcurrentHashMap的实现原理是将数据分成多个段(S...
    99+
    2023-09-19
    并发 数组 容器
  • 在JAVA项目中实现建造者模式的原理是什么
    本篇文章给大家分享的是有关在JAVA项目中实现建造者模式的原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。建造者模式:将复杂对象的构造与它的实现相分离,让相同的构建过程...
    99+
    2023-05-31
    java ava 建造者模式
  • Java项目中适配器模式的原理是什么
    Java项目中适配器模式的原理是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。适配器模式是把一个类的接口适配成用户所期待的,使得原本由于接口不兼容而不能一起工作的一些类可以...
    99+
    2023-05-31
    java ava 适配器模式
  • Java项目中反射机制的原理是什么
    今天就跟大家聊聊有关Java项目中反射机制的原理是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java 反射机制实例详解一、JAVA是动态语言吗?一般而言,说到动态言,都是指在...
    99+
    2023-05-31
    java 反射机制 ava
  • GO并发模型的实现原理是什么
    这篇文章主要介绍了GO并发模型的实现原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇GO并发模型的实现原理是什么文章都会有所收获,下面我们一起来看看吧。前言请记住下面这句话:DO NOT COMMUNI...
    99+
    2023-06-30
  • 禁止SpringBoot在项目中使用Tomcat容器的原理是什么
    这篇文章主要讲解了“禁止SpringBoot在项目中使用Tomcat容器的原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“禁止SpringBoot在项目中使用Tomcat容器的原理是...
    99+
    2023-07-02
  • 什么实现Java项目中的单一职责原则
    这期内容当中小编将会给大家带来有关什么实现Java项目中的单一职责原则,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。定义:不要存在多于一个导致类变更的原因。通俗的说,即一个类只负责一项职责。问题由来:类T...
    99+
    2023-05-31
    java 单一职责原则 ava
  • 如何在PHP项目中实现高并发处理?
    如何在PHP项目中实现高并发处理?随着互联网的迅猛发展,越来越多的网站和应用程序需要处理大量的并发请求。PHP作为一种常用的脚本语言,也面临着如何处理高并发的挑战。本文将介绍一些在PHP项目中实现高并发处理的方法和技巧。使用缓存使用缓存是提...
    99+
    2023-11-02
    高并发 处理 PHP项目
  • mysql中并发控制的原理是什么
    mysql中并发控制的原理是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、mysql的逻辑框架mysql逻辑框架图如下:最上层是处...
    99+
    2024-04-02
  • java 中集合的实现原理是什么
    本篇文章给大家分享的是有关java 中集合的实现原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、HashMappublic class Hash...
    99+
    2023-06-20
  • Node高并发的原理是什么
    这篇文章主要介绍“Node高并发的原理是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Node高并发的原理是什么”文章能帮助大家解决问题。从头聊起一个常见web应用会做哪些事情运算(执行业务逻辑...
    99+
    2023-07-04
  • Java并发程序出现Bug的原因是什么
    本篇内容介绍了“Java并发程序出现Bug的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 可见性问题可见性是指一个线程...
    99+
    2023-06-16
  • 如何在java项目中实现一个高并发锁
    如何在java项目中实现一个高并发锁?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。乐观锁乐观锁适合这样的场景:读不会冲突,写会冲突。同时读的频率远大于写。以下面的代码为例,悲观...
    99+
    2023-05-31
    java 高并发锁 ava
  • java迭代器实现的原理是什么
    Java迭代器的实现原理是基于设计模式中的迭代器模式。迭代器模式是一种行为型模式,它提供了一种方法来顺序访问一个聚合对象中的元素,而...
    99+
    2023-10-10
    java
  • Java AQS的实现原理是什么
    这篇文章主要介绍“Java AQS的实现原理是什么”,在日常操作中,相信很多人在Java AQS的实现原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java AQS的实...
    99+
    2023-07-05
  • java原子类实现的原理是什么
    Java原子类的实现原理是利用了底层的CAS(Compare and Swap)操作。CAS是一种乐观锁机制,它包含三个参数:内存位...
    99+
    2023-10-18
    java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作