当前位置: 首页 > news >正文

Android ---【经验篇】ArrayList vs CopyOnWriteArrayList 核心区别,怎么选择?

既然已有 ArrayList,为什么还要用 CopyOnWriteArrayList?核心原因是线程安全—— 这也是两者最本质的区别,下面我用简洁的方式讲清楚核心差异和选型逻辑:

一、ArrayList vs CopyOnWriteArrayList 核心区别

二、为什么不能直接用 ArrayList?(核心问题)

ArrayList 是日常开发中最常用的列表,但多线程环境下直接用会出严重问题:

  1. 数据错乱(最常见)
    比如两个线程同时往 ArrayList 添加元素,可能导致:
    元素丢失(一个线程的添加操作被覆盖);
    数组越界(ArrayList 扩容时的非原子操作导致);
    元素位置错乱(索引计算错误)。
  2. 并发修改异常
    如果一个线程迭代 ArrayList,另一个线程修改它(add/remove),会直接抛出 ConcurrentModificationException,导致程序崩溃。
    示例:ArrayList 多线程问题
importjava.util.ArrayList;importjava.util.List;publicclassArrayListThreadProblem{publicstaticvoidmain(String[]args){List<String>list=newArrayList<>();// 线程1:添加元素newThread(()->{for(inti=0;i<1000;i++){list.add("test"+i);}}).start();// 线程2:迭代+删除元素newThread(()->{for(Strings:list){// 迭代时修改,大概率抛异常list.remove(s);}}).start();}}

运行这段代码,要么抛 ConcurrentModificationException,要么出现数组越界、元素丢失等问题。

三、什么时候用 ArrayList?什么时候用 CopyOnWriteArrayList?

👉 用 ArrayList 的场景(90% 日常开发)
单线程环境(如主线程、单个业务线程);
不需要线程安全,追求极致的读写效率;
写操作频繁(比如频繁增删改数据)。
👉 用 CopyOnWriteArrayList 的场景(仅 10% 高并发场景)
多线程环境,且读操作远多于写操作(比如:系统配置列表、商品分类列表,加载后极少修改,频繁查询);
需要避免并发修改异常;
能接受写操作的性能开销(因为写得少,整体性能仍可控)。

四、补充:如果既想要 ArrayList 又想要线程安全,还有别的选择吗?

如果你的场景是 “写操作也比较频繁”,既不想用 ArrayList 踩线程安全的坑,也不想用 CopyOnWriteArrayList 承受写操作的性能开销,可选择:
Collections.synchronizedList(new ArrayList<>()):给 ArrayList 加全局锁,读写都加锁,线程安全但读操作会被阻塞(效率比 CopyOnWriteArrayList 低);
JDK 8+ 推荐用 ConcurrentLinkedDeque(实现 List/Queue 接口):读写效率都高,适合写操作稍多的并发场景。

总结

单线程 / 无并发:直接用 ArrayList(效率最高,无额外开销);
多线程 + 读多写少:用 CopyOnWriteArrayList(读无锁高效,写安全);
多线程 + 写操作频繁:别用 CopyOnWriteArrayList,选 synchronizedList 或 ConcurrentLinkedDeque;
核心原则:ArrayList 是 “高效但不安全”,CopyOnWriteArrayList 是 “安全且读高效,但写低效”,按需选型即可。

CopyOnWriteArrayList 的详细讲解请见:Android —【经验篇】CopyOnWriteArrayList 的使用场景及讲解

http://www.jsqmd.com/news/119858/

相关文章:

  • 为WPF应用增加项目图标
  • CSS 核心基础:样式表与选择器入门
  • Thinkphp和Laravel酒店客房 vue
  • Thinkphp和Laravel基于vue的校园社团管理系统
  • 5D动感影院设备投资成本及球幕影院市场前景分析
  • 【课程设计/毕业设计】基于SpringBoot的公司资产管理系统设计与实现基于springboot的闲置资产管理系统的设计与实现【附源码、数据库、万字文档】
  • Thinkphp和Laravel基于web的企业公司高校固定资产管理系统_mu8ut-vue
  • qt5之实现一个视频播放器(亲测好用)
  • 【毕业设计】基于springboot的闲置资产管理系统的设计与实现(源码+文档+远程调试,全bao定制等)
  • 写论文软件哪个好?虎贲等考 AI 解锁智能写作新范式,告别创作焦虑
  • 毕业季必看:6款靠谱AI写论文工具,查重率低于8%,原创度超高!
  • python:报错:ModuleNotFoundError: No module named pdfplumber
  • Windows系统文件efswrt.dll丢失或损坏 下载修复方法
  • 审稿 一区期刊注意事项: journal offers the option to connec;please note, reviewers are not expected 是什么意思
  • Docker 部署与管理 - 详解
  • 线性代数:多维世界的变形工具箱
  • 【计算机毕业设计案例】基于springboot的云与糖蛋糕购物平台系统的设计与实现烘焙行业线上线下融合、个性化定制服务(程序+文档+讲解+定制)
  • 免杀对抗——C2远控篇CC++DLL注入过内存核晶镂空新增白加黑链签名工具劫持
  • 支付宝底部导航栏变体+交互制作步骤
  • A.每日一题——955. 删列造序 II
  • python: 报错: ModuleNotFoundError: No module named fitz
  • 【计算机毕业设计案例】基于springboot的实验室预约系统的设计与实现实验室使用情况设备预约、时段管控、使用记录及安全监管的数字化服务(程序+文档+讲解+定制)
  • Select用法
  • 计算机Java毕设实战-基于SpringBoot+Vue实现的前后端分离在线考试系统基于springboot的在线考试系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 【毕业设计】基于springboot的在线考试系统的设计与实现(源码+文档+远程调试,全bao定制等)
  • 计算机Java毕设实战-基于springboot的闲置资产管理系统的设计与实现基于SpringBoot的闲置固定资产管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • Level 10 → Level 11
  • OKR 要不要考核?
  • 【课程设计/毕业设计】基于springboot的在线考试系统的设计与实现考试评分管理,试卷管理【附源码、数据库、万字文档】
  • go项目使用go build 与 MakeFile 构建项目