Package org.apache.bcel.util
Class MemorySensitiveClassPathRepository
java.lang.Object
org.apache.bcel.util.MemorySensitiveClassPathRepository
- All Implemented Interfaces:
Repository
- Direct Known Subclasses:
SyntheticRepository
This repository is used in situations where a Class is created outside the realm of a ClassLoader. Classes are loaded from the file systems using the paths
specified in the given class path. By default, this is the value returned by ClassPath.getClassPath(). This repository holds onto classes with
SoftReferences, and will reload as needed, in cases where memory sizes are important.
- See Also:
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
clear()
Clear all entries from cache.Find an already defined (cached) JavaClass object by name.Gets the ClassPath associated with this RepositoryFinds the JavaClass object for a runtime Class object.Finds a JavaClass object by name.void
removeClass
(JavaClass clazz) Remove class from repositoryvoid
storeClass
(JavaClass clazz) Store a new JavaClass instance into this Repository.
-
Constructor Details
-
MemorySensitiveClassPathRepository
-
-
Method Details
-
storeClass
Store a new JavaClass instance into this Repository.- Specified by:
storeClass
in interfaceRepository
-
removeClass
Remove class from repository- Specified by:
removeClass
in interfaceRepository
-
findClass
Find an already defined (cached) JavaClass object by name.- Specified by:
findClass
in interfaceRepository
-
clear
public void clear()Clear all entries from cache.- Specified by:
clear
in interfaceRepository
-
loadClass
Finds a JavaClass object by name. If it is already in this Repository, the Repository version is returned. Otherwise, the Repository's classpath is searched for the class (and it is added to the Repository if found).- Specified by:
loadClass
in interfaceRepository
- Parameters:
className
- the name of the class- Returns:
- the JavaClass object
- Throws:
ClassNotFoundException
- if the class is not in the Repository, and could not be found on the classpath
-
loadClass
Finds the JavaClass object for a runtime Class object. If a class with the same name is already in this Repository, the Repository version is returned. Otherwise, getResourceAsStream() is called on the Class object to find the class's representation. If the representation is found, it is added to the Repository.- Specified by:
loadClass
in interfaceRepository
- Parameters:
clazz
- the runtime Class object- Returns:
- JavaClass object for given runtime class
- Throws:
ClassNotFoundException
- if the class is not in the Repository, and its representation could not be found- See Also:
-
getClassPath
Description copied from interface:Repository
Gets the ClassPath associated with this Repository- Specified by:
getClassPath
in interfaceRepository
-