Get up to 80 % extra points for free! More info:

Lesson 8 - Multithreading in Java - Barrier, CountDownLatch

In the previous lesson, Multithreading in Java - Mutex, we looked at Mutexes. Today, we're going to discuss another very important synchronization primitive in Java - Barrier. And along with the barrier, let's take a look at one more synchronizing primitive, CountDownLatch.


Barrier serves as a synchronization primitive for a group of threads/processes. It's usually used when we perform some very complicated calculation. Such a calculation can be split and done by multiple threads. Each thread will then calculate its own part. In most cases, further calculations are based on previous results. This means that if we split the calculation into several separate threads, we have to wait until all the threads have calculated the partial results. When the last thread finishes the work, we can calculate with the next calculation. And it's the barrier what will take care of waiting for the other threads.

The illustration below shows how the barrier works. There are four threads: A, B, C, D. The threads A, C and D have completed their work and are waiting for the thread B. When the B thread finishes its work, it "breaks through" the barrier and the work can continue:

A barrier sample

Barrier in Java

In Java, the barrier is represented by the


...End of the preview...
Continue further

You will gain knowledge worth hundreds of thousands for a few crowns

You've come here and that's great! We believe that the first lessons showed you something new and useful
Do you want to continue the course? Go to the premium section.

Limited offer: Learn all knowledge and save money

Buy all currently available lessons with exercise submitting and other features for an exclusive price $7.83
Current account balance $0
By buying this exclusive package, you'll have access to all 13 lessons in this course including exercise submitting while saving $1.35. This offer is limited for the first lessons only with an additional exclusive 15% discount.

This article is licensed: Premium, by buying this article, you agree with the terms of use.

What will you get from us in the next lessons?
  • Unlimited and permanent access to individual lessons.
  • High quality IT knowledge.
  • Skills to help you get your dream and well-paid job.

Article description

Requested article covers this content:

In this article, we'll introduce advanced techniques for parallel programming in Java. We'll describe Barrier and CountDownLatch.

You gain credits by supporting our network. This is done by sending a helpful amount of money to support the site, or by creating content for the network.

Article has been written for you by Petr Štechmüller