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

de.team33.patterns.pooling.ariel.XRProvider Maven / Gradle / Ivy

Go to download

Provides a simple pooling of "expensive", reusable but thread-sensitive instances.

There is a newer version: 1.22.0
Show newest version
package de.team33.patterns.pooling.ariel;

import de.team33.patterns.exceptional.dione.XSupplier;
import de.team33.patterns.expiry.tethys.XRecent;

/**
 * A tool that makes instances of a certain type available for the course of operations that require such an instance.
 * The instances provided are referred to as item in the following.
 * 

* The tool maintains a number of such items and only creates as many as are actually required at most at * the same time in its application context. The items are retained and reused for subsequent operations. *

* In this respect, this tool is suitable for providing item types whose instantiation is relatively * "expensive", which are rather unsuitable for concurrent access, but are designed for multiple or permanent use. * Database or other client-server connections may be an example. *

* Note: this implementation cannot detect when an internal operation is taking place in the course of an operation to * which the same item could be made available. *

* This implementation supports expiry and reinitialisation of provided items. *

* This implementation supports checked exceptions to occur while creating new item instances. * * @param The type of provided instances (items) * @param A type of exception that may be caused by the creation of new item instances. * @see Provider * @see XProvider * @see RProvider */ public class XRProvider extends XProviderBase { /** * Initializes a new instance giving an {@link XSupplier} that defines the intended initialization of a * new item. *

* Once an instance item is initialized it will expire and be renewed after a maximum idle time * or at least after a maximum lifetime. */ public XRProvider(final XSupplier newItem, final long maxIdle, final long maxLiving) { super(() -> new XRecent<>(newItem, maxIdle, maxLiving)); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy