org.nustaq.offheap.FreeList Maven / Gradle / Ivy
/*
* Copyright 2014 Ruediger Moeller.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.nustaq.offheap;
/**
* Created by ruedi on 04.07.14.
*/
public class FreeList {
long flists[][] = new long[32][]; // 16, 32, 64, 128, 256, 512, ..
int flIndex[] = new int[32];
// get freelist index for given length
int computeListIndex( int len ) {
int powIndex = 32-Integer.numberOfLeadingZeros(len-1);
return powIndex;
}
int computeLen( int len ) {
int powIndex = 32-Integer.numberOfLeadingZeros(len-1);
return 1< 0) {
return flists[index][--flIndex[index]];
}
return 0;
}
public void addToFree(long offset, int len) {
int index = computeListIndex(len);
if ( flists[index] == null )
flists[index] = new long[500];
if ( flIndex[index] >= flists[index].length ) {
long newFree[] = new long[Math.min(flists[index].length * 2, Integer.MAX_VALUE - 1)];
System.arraycopy(flists[index], 0, newFree, 0, flIndex[index]);
flists[index] = newFree;
}
flists[index][flIndex[index]++] = offset;
}
public static void main(String arg[]) {
FreeList li = new FreeList();
li.computeListIndex(13);
li.computeListIndex(16);
li.computeListIndex(15);
li.computeListIndex(17);
li.computeListIndex(99);
li.computeListIndex(777);
li.computeListIndex(127);
System.out.println((li.computeListIndex(777000)));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy