Java亿级流量高并发设计解决方案 之多线程并发包JUC

本文深入解析Java并发包JUC,包括CopyOnWriteLock实现并发写操作、ReadWriteLock的读写锁机制、ConcurrentHashMap的结构演变、BlockingQueue在排序和定时任务中的应用、CountDownLatch的多线程闭锁、CyclicBarrier的同步屏障以及FutureTask与Callable的多线程实现。同时,文章通过源码分析了并发包基石AQS的工作原理。
摘要由CSDN通过智能技术生成

1.JUC核心类的深度解析与使用案例

1.1使用CopyOnWriteLock实现并发写操作

原理:遇到写操作时,CopyOnWrite先将当前容器复制一份,然后向新的容器(复制后的容器)添加新的元素(不会直接在当前容器中添加元素);添加完后,再将引用指向新的容器,原容器等待GC回收。

所以CopyOnWrite更加适合“读多写少”的场景。

1.2使用ReadWriteLock实现读写锁
  • readLock():加了读锁的资源,在没有写锁的时候可以被多个线程共享。
  • writeLock():写锁,独占锁。加了写锁的资源, 不能再被其它线程读或者写
1.3ConcurrentHashMap的底层结构
  • java7中,hashmap使用数组+链表的方式实现。ConcurrentHashMap是对segment加锁,每一个元素是一个segment,加大了锁的粒度,保证了线程安全。
  • java8中,hashmap使用数组+红黑树的方式实现。ConcurrentHashMap则放弃了对segment加锁,转而使用volatile,严重时使用synchronized和CAS算法来保证线程安全。
1.4使用BlockingQueue实现排序和定时任务

BlockingQueue可以对队列中的元素排序,以及实现定时任务等功能。

1.5通过CountDownLatch实现多线程闭锁

CountDownLatch是一个同步工具类,可以用来协调多个线程的执行时间。如可以让a线程在b线程执行完之后执行。a在这时会一直等待b的执行。这个过程也叫“闭锁”(某个线程被堵在门外得一直等待)。

闭锁通常用于确保某个计算,确保某个服务,确保某个任务。

CountDownLatch类似一个倒计时,设置一个数字后,执行一个线程的任务后,调用一次 CountDownLatch ,计数器减一。直到减为0,释放。

1.6使用CyclicBarrier在多线程设置屏障

与 CountDownLatch的区别:

  • CountDownLatch:可以实现a和b全部执行完成后,c再去执行。

  • CyclicBarrier:可以实现a,b等到c就绪后,一起执行。

1.7使用FutureTask和Callable实现多线程

创建多线程,可以继承Thread类,或者实现Runnable接口。JUC还提供了一种实现方式,Callable+FutureTask。

FutureTask是客户端向服务端发起一个请求后,服务端会立即给客户端返回一个结果。但实际任务并没有执行。客户端在拿到假的响应的同时,服务端才会去执行任务,并在任务结束后,将真的执行结果返回给客户端。

这样做的好处是,客户端发起一个请求后,可以立马得到结果,而不用一直去等待服务端的执行结果。

2.通过源码掌握并发包的基石AQS

AQS中维护着一个表示共享资源加锁状态的一个变量volatile int state(标示该资源被加锁次数),以及一个FIFO的线程阻塞队列CLH队列

多个线程访问共享资源时,如果资源已经被加了锁,那么所有线程将会加入CLH队列中进行等待。

加锁方式有两种

  • 独占锁Exclusive
  • 共享锁Share
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

匿名王同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值