Package ghidra.util.datastruct
Class ObjectCache
java.lang.Object
ghidra.util.datastruct.ObjectCache
ObjectClass
provides a fixed-size long-key-based object cache.
Both a hard and weak cache are maintained, where the weak cache is only
limited by available memory. This cache mechanism is useful in ensuring that
only a single object instance for a given key exists.
The weak cache is keyed, while the hard cache simply maintains the presence of an object in the weak cache.
-
Constructor Summary
ConstructorDescriptionObjectCache
(int hardCacheSize) Construct a keyed-object cache of size hardCacheSize. -
Method Summary
Modifier and TypeMethodDescriptionboolean
contains
(long key) Determine if the keyed-object exists in the cache.get
(long key) Get the object from cache which corresponds to the specified key.void
Add an object to the cachevoid
remove
(long key) Remove the specified keyed object from both hard and weak caches.void
setHardCacheSize
(int size) Adjust the hard cache sizeint
size()
Return the hard cache size
-
Constructor Details
-
ObjectCache
public ObjectCache(int hardCacheSize) Construct a keyed-object cache of size hardCacheSize.- Parameters:
hardCacheSize
- hard cache size.
-
-
Method Details
-
contains
public boolean contains(long key) Determine if the keyed-object exists in the cache.- Parameters:
key
- object key- Returns:
- true if object is cached
-
get
Get the object from cache which corresponds to the specified key.- Parameters:
key
- object key- Returns:
- cached object
-
size
public int size()Return the hard cache size- Returns:
- the hard cache size
-
setHardCacheSize
public void setHardCacheSize(int size) Adjust the hard cache size- Parameters:
size
- new hard cache size
-
put
Add an object to the cache- Parameters:
key
- object keyobj
- the object
-
remove
public void remove(long key) Remove the specified keyed object from both hard and weak caches. An object should be removed from the cache when it becomes invalid.- Parameters:
key
- object key
-