Jak jest używany CountDownLatch w wielowątkowości Java?

Czy ktoś może mi pomóc zrozumieć, czym jest JavaCountDownLatch czy i kiedy go używać?

Nie mam jasnego pojęcia, jak działa ten program. Jak rozumiem wszystkie trzy wątki zaczynają się od razu, a każdy wątek wywoła CountDownLatch po 3000ms. Tak więc odliczanie zmniejszy się jeden po drugim. Gdy zatrzask stanie się zerowy, program wydrukuje „Zakończono”. Może sposób, w jaki zrozumiałem, jest nieprawidłowy.

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

class Processor implements Runnable {
    private CountDownLatch latch;

    public Processor(CountDownLatch latch) {
        this.latch = latch;
    }

    public void run() {
        System.out.println("Started.");

        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        latch.countDown();
    }
}

// ------------------------------------------------ -----

public class App {

    public static void main(String[] args) {

        CountDownLatch latch = new CountDownLatch(3); // coundown from 3 to 0

        ExecutorService executor = Executors.newFixedThreadPool(3); // 3 Threads in pool

        for(int i=0; i < 3; i++) {
            executor.submit(new Processor(latch)); // ref to latch. each time call new Processes latch will count down by 1
        }

        try {
            latch.await();  // wait until latch counted down to 0
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("Completed.");
    }

}

questionAnswers(11)

yourAnswerToTheQuestion