根据Javadoc文档:
CountDownLatch会初始化为一个给定的计数。await方法会阻塞,直到当前计数达到零。
这意味着在下面的代码中,由于我将CountDownLatch初始化为1,所有线程应该在latch调用countdown时从await方法中解除阻塞。
但是,主线程正在等待所有线程完成。并且,我没有将主线程加入到其他线程的末尾。为什么主线程还在等待?
这意味着在下面的代码中,由于我将CountDownLatch初始化为1,所有线程应该在latch调用countdown时从await方法中解除阻塞。
但是,主线程正在等待所有线程完成。并且,我没有将主线程加入到其他线程的末尾。为什么主线程还在等待?
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.atomic.AtomicLong;
public class Sample implements Runnable {
private CountDownLatch latch;
public Sample(CountDownLatch latch)
{
this.latch = latch;
}
private static AtomicLong number = new AtomicLong(0);
public long next() {
return number.getAndIncrement();
}
public static void main(String[] args) {
CountDownLatch latch = new CountDownLatch(1);
for (int threadNo = 0; threadNo < 4000; threadNo++) {
Runnable t = new Sample(latch);
new Thread(t).start();
}
try {
latch.countDown();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public void run() {
try {
latch.await();
Thread.sleep(100);
System.out.println("Count:"+next());
} catch (Exception e) {
e.printStackTrace();
}
}
}
Thread.sleep(1000 + (int) ( Math.random() * 3000 ));
的调用中添加了一些随机性,以及在latch.await()
之后添加了一个打印语句,结果如预期。 - ulmangt