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

io.helidon.http.IntSet Maven / Gradle / Ivy

/*
 * Copyright (c) 2022, 2023 Oracle and/or its affiliates.
 *
 * 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 io.helidon.http;

/**
 * A Set like implementation optimized for integers.
 */
class IntSet {
    private final long[] data;
    private int size;

    /**
     * Create a new set.
     *
     * @param sizeInBits expected size
     */
    IntSet(int sizeInBits) {
        data = new long[(sizeInBits + 63) / 64];
    }

    /**
     * Get next value.
     *
     * 
     * for(int i=bs.nextSetBit(0); i>=0; i=bs.nextSetBit(i+1)) {
     *   // operate on index i here
     * }
     * 
* * @param i index * @return next value */ public int nextSetBit(int i) { int x = i / 64; if (x >= data.length) { return -1; } long w = data[x]; w >>>= (i % 64); if (w != 0) { return i + Long.numberOfTrailingZeros(w); } ++x; for (; x < data.length; ++x) { if (data[x] != 0) { return x * 64 + Long.numberOfTrailingZeros(data[x]); } } return -1; } /** * Add next value. * * @param i value */ public void add(int i) { data[i / 64] |= (1L << (i % 64)); size++; } /** * Remove a value. * * @param i value */ public void remove(int i) { data[i / 64] &= ~(1L << (i % 64)); size--; } /** * Current size. * * @return size */ public int size() { return size; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy