Class XProvider<I,E extends Exception>

java.lang.Object
de.team33.patterns.pooling.ariel.XProvider<I,E>
Type Parameters:
I - The type of provided instances (items)
E - A type of exception that may be caused by the creation of new item instances.

public class XProvider<I,E extends Exception> extends Object
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 checked exceptions to occur while creating new item instances.

See Also:
  • Constructor Details

    • XProvider

      public XProvider(XSupplier<? extends I,? extends E> newItem)
      Initializes a new instance giving an XSupplier that defines the intended initialization of a new item.
  • Method Details

    • run

      public final void run(Consumer<? super I> consumer) throws E
      Runs a given Consumer with a parameter provided for it. The parameter is kept for future use.

      While the Consumer is being executed, the parameter is exclusively available to it, but must not be "hijacked" from the context of the execution or the executing thread!

      Throws:
      E extends Exception - if the initialization of a new item causes one.
    • runEx

      public final <X extends Exception> void runEx(XConsumer<? super I,X> xConsumer) throws E, X
      Runs a given XConsumer with a parameter provided for it. The parameter is kept for future use.

      While the XConsumer is being executed, the parameter is exclusively available to it, but must not be "hijacked" from the context of the execution or the executing thread!

      Type Parameters:
      X - A type of exception that may be caused by the given XConsumer.
      Throws:
      E extends Exception - if the initialization of a new item causes one.
      X - if the execution of the given XConsumer causes one.
    • get

      public final <R> R get(Function<? super I,R> function) throws E
      Calls a given Function with a parameter provided for it and returns its result. The parameter is kept for future use.

      While the Function is being called, the parameter is exclusively available to it, but must not be "hijacked" from the context of the call or the executing thread!

      Type Parameters:
      R - The result type of the given Function
      Throws:
      E extends Exception - if the initialization of a new item causes one.
    • getEx

      public final <R, X extends Exception> R getEx(XFunction<? super I,R,X> xFunction) throws E, X
      Calls a given XFunction with a parameter provided for it and returns its result. The parameter is kept for future use.

      While the XFunction is being called, the parameter is exclusively available to it, but must not be "hijacked" from the context of the call or the executing thread!

      Type Parameters:
      R - The result type of the given XFunction
      X - A type of exception that may be caused by the given XFunction.
      Throws:
      E extends Exception - if the initialization of a new item causes one.
      X - if the execution of the given XFunction causes one.
    • size

      public final int size()
      Returns the number of currently unused subjects in stock.