Class LazyInitializer<T>
- Type Parameters:
- T- the type of the object managed by the initializer.
- All Implemented Interfaces:
- ConcurrentInitializer<T>,- FailableSupplier<T,- ConcurrentException> 
Sometimes an application has to deal with an object only under certain circumstances, e.g. when the user selects a specific menu item or if a special event is received. If the creation of the object is costly or the consumption of memory or other system resources is significant, it may make sense to defer the creation of this object until it is really needed. This is a use case for the lazy initialization pattern.
 This abstract base class provides an implementation of the double-check idiom for an instance field as discussed in Joshua Bloch's "Effective Java", 2nd
 edition, item 71. The class already implements all necessary synchronization. A concrete subclass has to implement the initialize() method, which
 actually creates the wrapped data object.
 
 As an usage example consider that we have a class ComplexObject whose instantiation is a complex operation. In order to apply lazy initialization to
 this class, a subclass of LazyInitializer has to be created:
 
 public class ComplexObjectInitializer extends LazyInitializer<ComplexObject> {
     @Override
     protected ComplexObject initialize() {
         return new ComplexObject();
     }
 }
 
 
 Access to the data object is provided through the get() method. So, code that wants to obtain the ComplexObject instance would simply look
 like this:
 
// Create an instance of the lazy initializer ComplexObjectInitializer initializer = new ComplexObjectInitializer(); ... // When the object is actually needed: ComplexObject cobj = initializer.get();
 If multiple threads call the get() method when the object has not yet been created, they are blocked until initialization completes. The algorithm
 guarantees that only a single instance of the wrapped object class is created, which is passed to all callers. Once initialized, calls to the get()
 method are pretty fast because no synchronization is needed (only an access to a volatile member field).
 
- Since:
- 3.0
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classLazyInitializer.Builder<I extends LazyInitializer<T>,T> Builds a new instance.Nested classes/interfaces inherited from class org.apache.commons.lang3.concurrent.AbstractConcurrentInitializerAbstractConcurrentInitializer.AbstractBuilder<I extends AbstractConcurrentInitializer<T,E>, T, B extends AbstractConcurrentInitializer.AbstractBuilder<I, T, B, E>, E extends Exception> 
- 
Field SummaryFields inherited from interface org.apache.commons.lang3.function.FailableSupplierNUL
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic <T> LazyInitializer.Builder<LazyInitializer<T>, T> builder()Creates a new builder.get()Gets the object wrapped by this instance.protected ConcurrentExceptionGets an Exception with a type of E as defined by a concrete subclass of this class.booleanTests whether this instance is initialized.Methods inherited from class org.apache.commons.lang3.concurrent.AbstractConcurrentInitializerclose, initialize
- 
Constructor Details- 
LazyInitializerpublic LazyInitializer()Constructs a new instance.
 
- 
- 
Method Details- 
builderCreates a new builder.- Type Parameters:
- T- the type of object to build.
- Returns:
- a new builder.
- Since:
- 3.14.0
 
- 
getGets the object wrapped by this instance. On first access the object is created. After that it is cached and can be accessed pretty fast.- Returns:
- the object initialized by this LazyInitializer
- Throws:
- ConcurrentException- if an error occurred during initialization of the object
 
- 
getTypedExceptionGets an Exception with a type of E as defined by a concrete subclass of this class.- Specified by:
- getTypedExceptionin class- AbstractConcurrentInitializer<T,- ConcurrentException> 
- Parameters:
- e- The actual exception that was thrown
- Returns:
- a new exception with the actual type of E, that wraps e.
 
- 
isInitializedTests whether this instance is initialized. Once initialized, always returns true.- Specified by:
- isInitializedin class- AbstractConcurrentInitializer<T,- ConcurrentException> 
- Returns:
- whether this instance is initialized. Once initialized, always returns true.
- Since:
- 3.14.0
 
 
-