public class EnvironmentCache
extends java.lang.Object
ClassLoader
)
Value : groupContext::SPI Cache (HashMap
)
//- groupContext::Object Cache
// Cache : HashMap
// Key : groupContext (String
)
// Value : Object
When we 'release', it is expected that the caller of the 'release'
have the same thread context class loader... as that will be used
to identify cached entries to be released.Modifier and Type | Field and Description |
---|---|
static int |
smallHashSize
Initial hash size for SPI's, default just seem TO big today..
|
Constructor and Description |
---|
EnvironmentCache() |
Modifier and Type | Method and Description |
---|---|
static java.lang.Object |
get(java.lang.ClassLoader classLoader)
Get object keyed by classLoader.
|
static void |
put(java.lang.ClassLoader classLoader,
java.lang.Object object)
Put service keyed by spi & classLoader.
|
static void |
release()
Release all internal references to previously created service
instances associated with the current thread context class loader.
|
static void |
release(java.lang.ClassLoader classLoader)
Release any internal references to a previously created service
instance associated with the current thread context class loader.
|
public static final int smallHashSize
public static java.lang.Object get(java.lang.ClassLoader classLoader)
public static void put(java.lang.ClassLoader classLoader, java.lang.Object object)
public static void release()
release()
method is called for service instances that
implement the Service
interface.
This is useful in environments like servlet containers,
which implement application reloading by throwing away a ClassLoader.
Dangling references to objects in that class loader would prevent
garbage collection.public static void release(java.lang.ClassLoader classLoader)
Service
, then call
release()
.Copyright (c) 2002 - Apache Software Foundation