Package org.jsoup.internal
Class SoftPool<T>
java.lang.Object
org.jsoup.internal.SoftPool<T>
- Type Parameters:
T- the type of object to pool.
A SoftPool is a ThreadLocal that holds a SoftReference to a pool of initializable objects. This allows us to reuse
expensive objects (buffers, etc.) between invocations (the ThreadLocal), but also for those objects to be reaped if
they are no longer in use.
Like a ThreadLocal, should be stored in a static field.
- Since:
- 1.18.2
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) static final intHow many total uses of the creating object might be instantiated on the same thread at once.(package private) final ThreadLocal<SoftReference<ArrayDeque<T>>> -
Constructor Summary
Constructors -
Method Summary
-
Field Details
-
threadLocalStack
-
initializer
-
MaxIdle
static final int MaxIdleHow many total uses of the creating object might be instantiated on the same thread at once. More than this and those objects aren't recycled. Doesn't need to be too conservative, as they can still be GCed as SoftRefs.- See Also:
-
-
Constructor Details
-
SoftPool
Create a new SoftPool.- Parameters:
initializer- a supplier that creates a new object when one is needed.
-
-
Method Details
-
borrow
Borrow an object from the pool, creating a new one if the pool is empty. Make sure to release it back to the pool when done, so that it can be reused.- Returns:
- an object from the pool, as defined by the initializer.
-
release
Release an object back to the pool. If the pool is full, the object is not retained. If you don't want to reuse a borrowed object (for e.g. a StringBuilder that grew too large), just don't release it.- Parameters:
value- the object to release back to the pool.
-
getStack
ArrayDeque<T> getStack()
-