高并发场景下ArrayList的线程安全问题

ArrayList是我们常用的数据结构,在并发场景下是线程不安全的。

在读多写少的场景下,我们一般会用读写锁 ReadWriteLock来保证共享对象的线程安全性。

public Object read() {
 lock.readLock().lock();
 // 对ArrayList读取
 lock.readLock().unlock();
}

public void write() {
 lock.writeLock().lock();
 // 对ArrayList写
 lock.writeLock().unlock();
}

这里能解决部分问题。但是还是存在当有一个线程在write的时候,其他读线程会被阻塞,假如这时候有大量的读请求访问,这时候都会被阻塞,这时候我们怎么办?

 CopyOnWrite 思想解决问题

很简单,顾名思义,利用“CopyOnWrite”的方式,这个英语翻译成中文,大概就是“写数据的时候利用拷贝的副本来执行

这里最关键的就是,在写线程修改完数据后,读线程能访问到最新数据。

这时候需要配合关键字 volatile

// 这个数组是核心的,因为用volatile修饰了
// 只要把最新的数组对他赋值,其他线程立马可以看到最新的数组 
private transient volatile Object[] array;
public boolean add
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值