parent
cef5fde343
commit
787fec0658
@ -1,71 +0,0 @@
|
||||
/**
|
||||
* UpDownLatch
|
||||
* Copyright 2011 by Michael Peter Christen, mc@yacy.net, Frankfurt a. M., Germany
|
||||
* First released 16.07.2011 at http://yacy.net
|
||||
*
|
||||
* $LastChangedDate: 2011-05-30 10:53:58 +0200 (Mo, 30 Mai 2011) $
|
||||
* $LastChangedRevision: 7759 $
|
||||
* $LastChangedBy: orbiter $
|
||||
*
|
||||
* This library 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.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library 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 this program in the file lgpl21.txt
|
||||
* If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
package net.yacy.cora.sorting;
|
||||
|
||||
import java.util.concurrent.locks.AbstractQueuedSynchronizer;
|
||||
|
||||
public class UpDownLatch extends AbstractQueuedSynchronizer {
|
||||
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
public UpDownLatch(final int count) {
|
||||
setState(count);
|
||||
}
|
||||
|
||||
public int getCount() {
|
||||
return getState();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int tryAcquireShared(final int acquires) {
|
||||
return getState() == 0? 1 : -1;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean tryReleaseShared(final int releases) {
|
||||
// Decrement count; signal when transition to zero
|
||||
for (;;) {
|
||||
final int c = getState();
|
||||
if (c == 0) return false;
|
||||
final int nextc = c-1;
|
||||
if (compareAndSetState(c, nextc)) return nextc == 0;
|
||||
}
|
||||
}
|
||||
|
||||
public void countUp() {
|
||||
for (;;) {
|
||||
final int c = getState();
|
||||
if (compareAndSetState(c, c + 1)) return;
|
||||
}
|
||||
}
|
||||
|
||||
public void countDown() {
|
||||
releaseShared(1);
|
||||
}
|
||||
|
||||
public void await() throws InterruptedException {
|
||||
acquireSharedInterruptibly(1);
|
||||
}
|
||||
}
|
Loading…
Reference in new issue