One of the most complex and powerful functionalities offered by the Java concurrency API is the ability to execute concurrent-phased tasks using the
. This mechanism is useful when we have some concurrent tasks divided into steps. The
Phaser class provides us with the mechanism to synchronize the threads at the end of each step, so no thread starts its second step until all the threads have finished the first one.
As with other synchronization utilities, we have to initialize the
Phaser class with the number of tasks that participate in the synchronization operation, but we can dynamically modify this number by increasing or decreasing it.
In this recipe, you will learn how to use the
Phaser class to ...