All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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