通常我们所说的并发包也就是java.util.concurrent,集中了Java并发的各种工具类。

同步结构

  CountDownLatch  允许一个或多个线程等待某些操作完成  CountDownLatch操作的是事件

  CyclicBarrier  一种辅助性的同步结构,允许多个线程等待到大某个屏障  CyclicBarrier侧重点是线程

  Semaphore  Java版本的信号量实现

  Phaser  功能与CountDownLatch很接近,允许线程动态的注册到Phaser上面,而CountDownLatch是不能动态设置的。

      设计初衷是实现多个线程类似步骤、阶段场景的协调,线程注册等待屏障条件出发,进而协调彼此间的行动,具体参考这个例子

线程安全的容器

  ConcurrentHashMap、侧重于Map放入或者获取的速度,而不在乎顺序

  ConcurrentSkipListMap、在乎顺序,需要对数据进行非常频繁的修改

  CopyOnWriteArrayList  任何修改操作,如add、set、remove,都会拷贝原数组,修改后替换原来的数组,通过这种防御性的方式,实现另类的线程安全。

  CopyOnWriteArraySet

各种并发队列的实现:如各种BlockedQueue实现,比较典型的ArrayBlockingQueue、SynchorousQueue或针对特定场景的PriorityBlockingQueue等。

强大的Executor框架:可以创建各种不同类型的线程池,调度任务运行等,绝大部分情况下,不再需要自己从头实现线程池和任务调度器。

并发包里提供的线程安全Map、List和Set。参考下面类图

Java并发工具包提供了哪些并发工具类

ConcurrentHashMap

ConcurrentSkipListMap

两个CopyOnWrite容器CopyOnWriteArrayList和CopyOnWriteArraySet

Java并发工具包提供了哪些并发工具类

 

相关文章:

  • 2022-02-21
  • 2021-12-19
  • 2020-03-30
  • 2021-07-13
  • 2022-12-23
  • 2021-05-23
  • 2020-02-23
  • 2020-02-15
猜你喜欢
  • 2021-10-01
  • 2021-05-27
  • 2022-02-26
  • 2021-12-15
  • 2017-12-05
  • 2021-11-12
相关资源
相似解决方案