
dorkbox.objectPool.NonBlockingPool Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ObjectPool Show documentation
Show all versions of ObjectPool Show documentation
Fast, lightweight, and compatible blocking/non-blocking/soft-reference object pool for Java 6+
/*
* 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.
*/
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.
*/
public
T takeInterruptibly() throws InterruptedException {
return take();
}
/**
* Return object to the pool, waking the threads that have blocked during take()
*/
public
void put(T object) {
poolableObject.onReturn(object);
this.queue.offer(object);
}
/**
* @return a new object instance created by the pool.
*/
public
T newInstance() {
return poolableObject.create();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy