net.timewalker.ffmq4.utils.concurrent.SynchronizationBarrier Maven / Gradle / Ivy
/*
* This file is part of FFMQ.
*
* FFMQ is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* FFMQ is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with FFMQ; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package net.timewalker.ffmq4.utils.concurrent;
/**
* SynchronizationBarrier
*/
public final class SynchronizationBarrier
{
private boolean reached;
private int remaining;
/**
* Increment the number of involved parties
*/
public synchronized void addParty()
{
remaining++;
}
/**
* Test if the synchronization point was reached
*/
public synchronized boolean isReached()
{
return reached;
}
/**
* Wait for the synchronization point to be reached.
* Returns immediately if the sync. point is already reached.
*/
public synchronized void waitFor() throws InterruptedException
{
if (remaining == 0)
reached = true;
while (!reached)
wait();
}
/**
* Indicate that the current thread reached the synchronization barrier.
* If all parties have reached the barrier, this wakes up all waiting threads.
*/
public synchronized void reach()
{
if (reached)
return;
remaining--;
if (remaining <= 0)
{
reached = true;
notifyAll();
}
}
/**
* Reset the synchronization barrier
*/
public synchronized void reset()
{
remaining = 0;
reached = false;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy