CyclicBarrier-サイクルフェンス
それがフェンスに到達したときに呼び出さ待つスレッドがブロックされている場合、唯一のスレッドデータフェンス、フェンス解除によって設定された閾値に達すると、すべてのスレッドが、次のラウンドへのラウンド、フェンスの端を継続します。
ケース:フェンスは、3つのスレッドの解放を待っています
仕事
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class Task implements Runnable{
private CyclicBarrier cyclicBarrier;
public Task(CyclicBarrier cyclicBarrier) {
this.cyclicBarrier = cyclicBarrier;
}
@Override
public void run() {
try {
Thread.sleep(1000);
System.out.println(Thread.currentThread().getName() + "准备就绪");
cyclicBarrier.await();
} catch (InterruptedException e) {
System.out.println(Thread.currentThread().getName() + "中断了......");
} catch (BrokenBarrierException e) {
System.out.println(Thread.currentThread().getName() + "抛出损坏异常....");
}
}
}
スタートアップファイル
import java.util.concurrent.CyclicBarrier;
public class Main {
public static void main(String[] args) throws InterruptedException {
System.out.println("主线程开始......");
CyclicBarrier cb = new CyclicBarrier(3, new Runnable(){
@Override
public void run() {
System.out.println("子线程全部就位,开始执行制定任务......");
}
});
Thread t1 = new Thread(new Task(cb), "Thread-1");
Thread t2 = new Thread(new Task(cb), "Thread-2");
Thread t3 = new Thread(new Task(cb), "Thread-3");
t1.start();
t2.start();
t3.start();
Thread.sleep(2000);
System.out.println("主线程执行完毕");
}
}
結果:
CyclicBarrierを例外
CyclicBarrierをあなたがしきい値を満たす、またはタイムアウトのスレッドが中断されるのを待つことができない場合は、すべての待機中のスレッドは、次のラウンドに、例外ダメージを投げ、およびます。
ケース:異常な損傷は、4のしきい値を想定し、それは、中断のいずれかを待っている3件のスレッドがあります。
タスクコード変わらず
スタートアップファイルを変更します。
import java.util.concurrent.CyclicBarrier;
public class Main {
public static void main(String[] args) throws InterruptedException {
System.out.println("主线程开始......");
CyclicBarrier cb = new CyclicBarrier(4, new Runnable(){
@Override
public void run() {
System.out.println("子线程全部就位,开始执行制定任务......");
}
});
Thread t1 = new Thread(new Task(cb), "Thread-1");
Thread t2 = new Thread(new Task(cb), "Thread-2");
Thread t3 = new Thread(new Task(cb), "Thread-3");
t1.start();
t2.start();
t3.start();
Thread.sleep(1000);
t1.interrupt();
Thread.sleep(2000);
System.out.println("主线程执行完毕");
}
}
結果:
ソース分析:
ReentrantLockのと条件に基づいて、ロック機構を実現CyclicBarrierを。
メンバ変数
メソッドを待ちます。
breakBarrier被害方法: