- 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