在Java中,可以使用CyclicBarrier类来设置Barrier的阈值。CyclicBarrier类有一个构造方法,可以指定需要等待的线程数量作为参数,这个数量就是Barrier的阈值。当等待的线程数量达到指定的阈值时,所有线程将被释放并继续执行。
下面是一个示例代码,演示如何设置CyclicBarrier的阈值:
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class BarrierExample {
public static void main(String[] args) {
int numberOfThreads = 3; // 设置Barrier的阈值为3
CyclicBarrier barrier = new CyclicBarrier(numberOfThreads, new Runnable() {
@Override
public void run() {
System.out.println("All threads have reached the barrier");
}
});
for (int i = 0; i < numberOfThreads; i++) {
Thread thread = new Thread(new Worker(barrier));
thread.start();
}
}
static class Worker implements Runnable {
private CyclicBarrier barrier;
public Worker(CyclicBarrier barrier) {
this.barrier = barrier;
}
@Override
public void run() {
try {
System.out.println(Thread.currentThread().getName() + " is waiting at the barrier");
barrier.await(); // 等待所有线程到达Barrier
System.out.println(Thread.currentThread().getName() + " has passed the barrier");
} catch (InterruptedException | BrokenBarrierException e) {
e.printStackTrace();
}
}
}
}
在上面的示例中,我们创建了一个CyclicBarrier对象,并指定了阈值为3。然后创建了3个Worker线程,每个线程在执行过程中都会调用CyclicBarrier的await()方法来等待其他线程。当所有线程都到达Barrier时,会执行指定的Runnable任务,并继续执行各个线程。