谈谈Java并发包

本文深入探讨了Java并发包中的核心组件,包括阻塞队列BlockingQueue的工作原理,优先级队列PriorityBlockingQueue的实现方式,以及ConcurrentHashMap、ConcurrentNavigableMap的内部结构。此外,还详细介绍了闭锁CountDownLatch、栅栏CyclicBarrier和交换机Exchanger在多线程编程中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

谈谈Java并发包

一、阻塞队列BlockingQueue
  阻塞队列中未满时:
   add(…):成功添加,没有抛出异常,并返回true。
   put(…):成功添加,未产生阻塞。
   offer(…):成功添加,返回特定值true。
  阻塞队列中已满时:
    add():抛出Queue full异常。
    put():产生阻塞。
    offer():添加失败,返回特定值false。
  当阻塞队列还有元素的时候:
   remove():从队列删除掉,并返回该元素。
   take():从队列删除掉,并返回该元素。
   poll():从队列删除掉,并返回该元素。
  当阻塞队列空的时候:
   remove():抛出NoSuchElementException。
   take():产生阻塞。
   poll():返回特定值null。
二、PriorityBlockingQueue优先队列
  底层用最小堆来实现的
三、ConcurrentHashMap
  底层才有分段锁的概念实现的,使用16个分段,这样可以支持同时16个线程并发访问,映射的实现是链表数组,通过key的hashcode值去掉符号位,然后对数组长度进行取余,数组长度最好是素数,jdk8之后底层用链表和红黑树实现。
四、ConcurrentNavigableMap并发导航映射
  根据指定的key获取符合条件的子map,headMap()、tailMap()、subMap()
五、闭锁CountDownLatch
  java.util.concurrent.CountDownLatch 是一个并发构造,它允许一个或多个线程等待一系列指定操作的完成。
  CountDownLatch cdl = new CountDownLatch(2);//初始化控制的线程数量
  cdl.countDown();//在线程的run()方法中调用,每调用一次将计数器减1
  cdl.await();产生阻塞,直到计数器的值变成0时,阻塞释放
六、栅栏 CyclicBarrier
  用来管理线程的执行。CyclicBarrier(int count):count的值就是管理线程的数量,让它所管理的所有线程都执行到代码行await()进行等待,等待到所有的线程都执行过await(),在“同时”执行每一个线程后续的代码。
  await():将计数器减1,然后产生阻塞,栅栏管理所有线程都执行完,await()方法再释放。
  CyclicBarrier cb = new CyclicBarrier(2); cb.await();
七、交换机 Exchanger
  Exchanger ex = new Exchanger();
  String result = ex.exchange(info);//两个线程间传递信息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值