com.jaeksoft.searchlib.util.array.IntBufferedArrayFactory Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of opensearchserver Show documentation
Show all versions of opensearchserver Show documentation
OpenSearchServer is a powerful, enterprise-class, search engine program. Using the web user interface, the crawlers (web, file, database, ...) and the REST/RESTFul API you will be able to integrate quickly and easily advanced full-text search capabilities in your application. OpenSearchServer runs on Windows and Linux/Unix/BSD.
The newest version!
/**
* License Agreement for OpenSearchServer
*
* Copyright (C) 2014 Emmanuel Keller / Jaeksoft
*
* http://www.open-search-server.com
*
* This file is part of OpenSearchServer.
*
* OpenSearchServer is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation, either version 3 of the License, or (at your option) any
* later version.
*
* OpenSearchServer 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 General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* OpenSearchServer. If not, see .
**/
package com.jaeksoft.searchlib.util.array;
import it.unimi.dsi.fastutil.ints.IntArrayList;
import java.util.Random;
import com.jaeksoft.searchlib.util.NativeOss;
public abstract class IntBufferedArrayFactory {
public final static IntBufferedArrayFactory INSTANCE = NativeOss.loaded() ? new NativeFactory()
: new JavaFactory();
public abstract IntBufferedArrayInterface newInstance(final long maxSize);
final static private class NativeFactory extends IntBufferedArrayFactory {
@Override
public IntBufferedArrayInterface newInstance(final long maxSize) {
return new NativeIntBufferedArray(maxSize);
}
}
final static private class JavaFactory extends IntBufferedArrayFactory {
@Override
public IntBufferedArrayInterface newInstance(final long maxSize) {
return new IntBufferedArray(maxSize);
}
}
public static final void result(Object object, long startTime, long freemem) {
long elapsedTime = System.currentTimeMillis() - startTime;
System.out.println(object.getClass().getSimpleName() + " Time: "
+ elapsedTime + " Memory: "
+ (freemem - Runtime.getRuntime().freeMemory()) / 1024);
}
public final static void main(String[] str) {
final int size = 10000000;
Random random = new Random(System.currentTimeMillis());
// Building the index
long startTime = System.currentTimeMillis();
long freemem = Runtime.getRuntime().freeMemory();
int[] randomArray = new int[size];
for (int i = 0; i < size; i++)
randomArray[i++] = random.nextInt();
result(randomArray, startTime, freemem);
// Testing Native Array
System.gc();
startTime = System.currentTimeMillis();
freemem = Runtime.getRuntime().freeMemory();
int[] nativeArray1 = new int[size];
int i = 0;
for (int v : randomArray)
nativeArray1[i++] = v;
result(nativeArray1, startTime, freemem);
// Testing Native Array
System.gc();
startTime = System.currentTimeMillis();
freemem = Runtime.getRuntime().freeMemory();
int[] nativeArray = new int[size * 4];
i = 0;
for (int v : randomArray)
nativeArray[i++] = v;
check(randomArray, nativeArray);
result(nativeArray, startTime, freemem);
// Testing FastUTIL
System.gc();
startTime = System.currentTimeMillis();
freemem = Runtime.getRuntime().freeMemory();
IntArrayList fastUtilArray = new IntArrayList(size * 4);
for (int v : randomArray)
fastUtilArray.add(v);
check(randomArray, fastUtilArray.toIntArray());
result(fastUtilArray, startTime, freemem);
// Testing Buffered Array
System.gc();
startTime = System.currentTimeMillis();
freemem = Runtime.getRuntime().freeMemory();
IntBufferedArray intBufferedArray = new IntBufferedArray(size * 4);
for (int v : randomArray)
intBufferedArray.add(v);
result(intBufferedArray, startTime, freemem);
check(randomArray, intBufferedArray.getFinalArray());
result(intBufferedArray, startTime, freemem);
// Testing Native Array
System.gc();
startTime = System.currentTimeMillis();
freemem = Runtime.getRuntime().freeMemory();
IntBufferedArrayInterface ibai = INSTANCE.newInstance(size * 4);
for (int v : randomArray)
ibai.add(v);
result(ibai, startTime, freemem);
check(randomArray, ibai.getFinalArray());
result(ibai, startTime, freemem);
}
private static void check(int[] randomArray, int[] finalArray) {
if (randomArray.length > finalArray.length) {
System.err.println("BufferedArray corrupted (size)");
return;
}
int pos = 0;
for (int value : randomArray)
if (finalArray[pos++] != value) {
System.err.println("BufferedArray corrupted (content) " + pos);
return;
}
System.out.println("BufferedArray ok");
}
}