码迷,mamicode.com
首页 > 编程语言 > 详细

java中concurrent包内容

时间:2016-07-28 14:21:19      阅读:191      评论:0      收藏:0      [点我收藏+]

标签:

有BlockingQueue及其相关的类,跟阻塞队列有关系。 
ConcurrentHashMap,ConcurrentLinkedQueue等,这些是相关集合的线程同步版本。 
CopyOnWriteArrayList,也是一种并发用的容器,当我们改变这个数组的时候,先复制一个副本,修改这个副本,再复制回去。这样就实现了读写分离,适用于读多写少的并发场景。 
CountDownLatch,这个类适用于这种情况:多个线程同时工作,然后其中几个可以随意并发执行,但有一个线程需要等其他线程工作结束后,才能开始。 
该类里面维护一个计数器,通过构造器传入一个初始的count,里面有两个常用方法,一个是cutDown(),将计数器的数值-1,还有await(),调用await()的线程将一直阻塞,直到里面的计数器值为0。 
CountedCompleter,这是个java8新增的类,我也看不懂是干啥的,有兴趣的读者自行阅读Java文档:http://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CountedCompleter.html 
CyclicBarrier,同步屏障。当有许多线程并发执行时,可以设置一个屏障,让所有线程执行到屏障时阻塞,直到最后一个线程运行到屏障时,才让所有线程继续往下执行。 
DelayQueue,一个延迟阻塞队列,里面的对象只有在其到期的时候才能取走,否则阻塞线程。(之前第4期我们探讨过ScheduleThreadPoolExecutor的时候,里面就有这个东西) 
Exchanger,可以在两个线程之间交换数据,只能是2个线程,他不支持更多的线程之间互换数据。 
Executor一系列,跟线程池有关系。 
ForkJoinPool,Fork/Join模式下的线程池。据说是对多核支持比较好。 
FutureTask,是Future的实现,用于获取Callable和Runnable对象的执行状态、结果等。 
Phaser,是jdk7新增的一个线程同步工具,跟CountDownLatch和CyclicBarrier有些功能是重复的。 
Semaphore,就是OS课上学过的信号量,用于控制一个资源可同时被几个线程访问。 
SynchronousQueue,是一种队列,这种队列可以用来模拟生产-消费者模型,因为它的元素入队之后要想再入队必须等候一个出队操作。 
ThreadLocalRandom,一个线程同步的随机数生成器,在高并发下生成随机数比Random快。 
大致就这些了,还有一些类都是与之相关的。

还有两个子包atomic和locks,其中atomic是对一些数的再封装,保证在多线程下这些数的操作都是原子性的。(例如普通的i++就不是原子的)locks里面则是提供了各种线程同步锁,其中ReentrantLock比较常用。

上面说的都比较泛,如果真的要深度解析java.util.concurrent包中的每一个类,恐怕十篇博文都不够。

java中concurrent包内容

标签:

原文地址:http://www.cnblogs.com/govoid/p/5714477.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!