java多线程
文章平均质量分 75
月夜鬼影
这个作者很懒,什么都没留下…
展开
-
java.util.concurrent之CountDownLatch
CountDownLatch可用于管理一组线程,适用于将一个任务分成若干线程执行,等到所有线程执行完,再进行汇总处理。 package test; import java.util.concurrent.CountDownLatch; import java.util.concurrent.ExecutorService; import java.util.concurrent.Execut原创 2015-09-22 14:34:37 · 385 阅读 · 0 评论 -
java.util.concurrent之CyclicBarrier
JDK介绍:一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。 举例说明:一群人骑行,有些人骑得快,有些人骑的慢,但是每到一个休息地点必须等待所有人都到了才可以继续出发 代码如下: package test; import java.util.concurrent.CyclicBarrier; import java.util.c原创 2015-09-22 14:51:33 · 379 阅读 · 0 评论 -
java.util.concurrent之Semaphore
jdk介绍:一个计数信号量。从概念上讲,信号量维护了一个许可集。如有必要,在许可可用前会阻塞每一个 acquire(),然后再获取该许可。每个 release() 添加一个许可,从而可能释放一个正在阻塞的获取者。但是,不使用实际的许可对象,Semaphore 只对可用许可的号码进行计数,并采取相应的行动。 适用场景:有很多个线程,但是同一时间只允许n个线程执行,其他线程只能等待,除非获取执行许原创 2015-09-22 14:59:27 · 477 阅读 · 0 评论 -
java.util.concurrent之FutureTask
jdk介绍:可取消的异步计算。利用开始和取消计算的方法、查询计算是否完成的方法和获取计算结果的方法,此类提供了对 Future 的基本实现。仅在计算完成时才能获取结果;如果计算尚未完成,则阻塞 get 方法。一旦计算完成,就不能再重新开始或取消计算。 相当于新起一个线程去执行,不影响主线程其他代码执行,只不过获取线程结果时需要阻塞等待 代码如下: package test; impo原创 2015-09-22 15:11:06 · 2175 阅读 · 0 评论