Java多线程和事务控制
写一个Java类,这个Java类里面执行N个线程,每个线程里开启一个事务,并且线程都依赖一个 CyclicBarrier,通过这个 CyclicBarrier, 让所有线程完成各自的工作后互相等待,然后一起跨过这个障碍点。如果其中某个线程失败后,其他线程都要跟着失败。CyclicBarrier.await() 方法只抛出 InterruptedException, BrokenBarrierException
下面的 n 代表子线程数量(1,2,3...N)
final CyclicBarrier barrier = new CyclicBarrier(n, new Runnable() {
public void run() {
System.out.println("如有特殊需求,可在此处填写;比如发送消息等...");
}
});
//如无需特殊处理,也可以如下定义
final CyclicBarrier barrier = new CyclicBarrier(n);
举个例子:
//给10个线程分别一把锁,直到所有子线程完成