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

dorkbox.objectPool.NonBlockingPool Maven / Gradle / Ivy

/*
 * Copyright 2016 dorkbox, llc
 *
 * 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 dorkbox.objectPool;

import java.util.Queue;
import java.util.concurrent.ConcurrentLinkedQueue;

/**
 * A non-blocking pool which will grow as much as needed. If the pool is empty, new objects will be created. The items in the
 * pool will never expire or be automatically garbage collected. (see {@link #NonBlockingSoftReference(PoolableObject)} for pooled objects
 * that will expire/GC as needed).
 *
 * @author dorkbox, llc
 */
class NonBlockingPool extends ObjectPool {
    private final Queue queue;
    private final PoolableObject poolableObject;

    NonBlockingPool(final PoolableObject poolableObject) {
        this(poolableObject, new ConcurrentLinkedQueue());
    }

    NonBlockingPool(final PoolableObject poolableObject, final Queue queue) {
        this.poolableObject = poolableObject;
        this.queue = queue;
    }

    /**
     * Takes an object from the pool, Blocks until an item is available in the pool.
     */
    @Override
    public
    T take() {
        T take = this.queue.poll();
        if (take == null) {
            take = poolableObject.create();
        }

        poolableObject.onTake(take);
        return take;
    }

    /**
     * Takes an object from the pool, Blocks until an item is available in the pool.
     * 

* This method catches {@link InterruptedException} and discards it silently. */ @Override public T takeInterruptibly() throws InterruptedException { return take(); } /** * Return object to the pool, waking the threads that have blocked during take() */ @Override public void put(T object) { poolableObject.onReturn(object); this.queue.offer(object); } /** * @return a new object instance created by the pool. */ @Override public T newInstance() { return poolableObject.create(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy