public interface ICountDownLatch extends DistributedObject
java.util.concurrent.CountDownLatch.
 ICountDownLatch is a cluster-wide synchronization aid that allows one or more threads to wait until a set of operations being performed in other threads completes.
 There are a few differences compared to the
 java.util.concurrent.CountDownLatch:
 
trySetCount(int) after
 a countdown has finished but not during an active count. This allows
 the same latch instance to be reused.
 
 ICountDownLatch is accessed via
 CPSubsystem.getCountDownLatch(String). It works on top of the Raft
 consensus algorithm. It offers linearizability during crash failures and network
 partitions. It is CP with respect to the CAP principle. If a network
 partition occurs, it remains available on at most one side of the partition.
 
 All of the API methods in the new CP ICountDownLatch impl offer
 the exactly-once execution semantics. For instance, even if
 a countDown() call is internally retried because of crashed
 Hazelcast member, the counter value is decremented only once.
| Modifier and Type | Method and Description | 
|---|---|
| boolean | await(long timeout,
     TimeUnit unit)Causes the current thread to wait until the latch has counted down to
 zero, or an exception is thrown, or the specified waiting time elapses. | 
| void | countDown()Decrements the count of the latch, releasing all waiting threads if
 the count reaches zero. | 
| int | getCount()Returns the current count. | 
| boolean | trySetCount(int count)Sets the count to the given value if the current count is zero. | 
destroy, getDestroyContextForTenant, getName, getPartitionKey, getServiceNameboolean await(long timeout,
              TimeUnit unit)
       throws InterruptedException
 If the current count is zero then this method returns immediately
 with the value true.
 
If the current count is greater than zero, then the current thread becomes disabled for thread scheduling purposes and lies dormant until one of five things happen:
countDown() method,
 true.
 If the current thread:
InterruptedException is thrown and the current thread's
 interrupted status is cleared.
 
 If the specified waiting time elapses then the value false
 is returned.  If the time is less than or equal to zero, the method
 will not wait at all.
timeout - the maximum time to waitunit - the time unit of the timeout argumenttrue if the count reached zero, false
 if the waiting time elapsed before the count reached zeroInterruptedException - if the current thread is interruptedIllegalStateException - if the Hazelcast instance is shutdown while waitingNullPointerException - if unit is nullvoid countDown()
If the current count is greater than zero, then it is decremented. If the new count is zero:
null.
 int getCount()
boolean trySetCount(int count)
 If count is not zero, then this method does nothing and returns false.
count - the number of times countDown() must be invoked
              before threads can pass through await(long, java.util.concurrent.TimeUnit)true if the new count was set, false if the current count is not zeroIllegalArgumentException - if count is negative or zeroCopyright © 2023 Hazelcast, Inc.. All rights reserved.