Согласно Javadoc:
CountDownLatch инициализируется с заданным количеством. Методы await блокируются, пока текущий счетчик не достигнет нуля.
Это означает, что в приведенном ниже коде я инициализировал CountDownLatch равным 1. Все потоки должны разблокироваться от его метода 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();
}
}
}