- do not start worker threads in Array class if concurrency is not used git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@7844 6c8d7289-2bf4-0310-a012-ef5d649a1542pull/1/head
parent
48b78e9ff4
commit
3d043ce9d6
@ -0,0 +1,41 @@
|
||||
/**
|
||||
* Sortable
|
||||
* 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.storage;
|
||||
|
||||
import java.util.Comparator;
|
||||
|
||||
public interface Sortable<A> extends Comparator<A> {
|
||||
|
||||
public int size();
|
||||
|
||||
public A get(final int index, final boolean clone);
|
||||
|
||||
public void delete(int i);
|
||||
|
||||
public A buffer();
|
||||
|
||||
public void swap(int i, int j, A buffer);
|
||||
|
||||
}
|
@ -0,0 +1,69 @@
|
||||
/**
|
||||
* 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.storage;
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
public int tryAcquireShared(final int acquires) {
|
||||
return getState() == 0? 1 : -1;
|
||||
}
|
||||
|
||||
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);
|
||||
}
|
||||
}
|
@ -1,17 +0,0 @@
|
||||
package net.yacy.kelondro.order;
|
||||
|
||||
import java.util.Comparator;
|
||||
|
||||
public interface Sortable<A> extends Comparator<A> {
|
||||
|
||||
public int size();
|
||||
|
||||
public A get(final int index, final boolean clone);
|
||||
|
||||
public void delete(int i);
|
||||
|
||||
public A buffer();
|
||||
|
||||
public void swap(int i, int j, A buffer);
|
||||
|
||||
}
|
Loading…
Reference in new issue