@HashCodeAndEqualsPlugin.Enhance public static class ClassInjector.UsingReflection extends ClassInjector.AbstractBase
| Modifier and Type | Class and Description | 
|---|---|
protected static interface  | 
ClassInjector.UsingReflection.Dispatcher
A dispatcher for accessing a  
ClassLoader reflectively. | 
protected static interface  | 
ClassInjector.UsingReflection.System
A proxy of  
java.lang.System. | 
ClassInjector.AbstractBase, ClassInjector.UsingInstrumentation, ClassInjector.UsingJna, ClassInjector.UsingLookup, ClassInjector.UsingReflection, ClassInjector.UsingUnsafeALLOW_EXISTING_TYPES, SUPPRESS_ACCESS_CHECKS| Constructor and Description | 
|---|
UsingReflection(ClassLoader classLoader)
Creates a new injector for the given  
ClassLoader and a default ProtectionDomain and a
 trivial PackageDefinitionStrategy which does not trigger an error when discovering existent classes. | 
UsingReflection(ClassLoader classLoader,
               ProtectionDomain protectionDomain)
Creates a new injector for the given  
ClassLoader and a default PackageDefinitionStrategy where the
 injection of existent classes does not trigger an error. | 
UsingReflection(ClassLoader classLoader,
               ProtectionDomain protectionDomain,
               PackageDefinitionStrategy packageDefinitionStrategy,
               boolean forbidExisting)
Creates a new injector for the given  
ClassLoader and ProtectionDomain. | 
| Modifier and Type | Method and Description | 
|---|---|
Map<String,Class<?>> | 
injectRaw(Map<? extends String,byte[]> types)
Injects the given types into the represented class loader using a mapping from name to binary representation. 
 | 
boolean | 
isAlive()
Indicates if this class injector is available on the current VM. 
 | 
static boolean | 
isAvailable()
Indicates if this class injection is available on the current VM. 
 | 
static ClassInjector | 
ofSystemClassLoader()
Creates a class injector for the system class loader. 
 | 
injectpublic UsingReflection(ClassLoader classLoader)
ClassLoader and a default ProtectionDomain and a
 trivial PackageDefinitionStrategy which does not trigger an error when discovering existent classes.classLoader - The ClassLoader into which new class definitions are to be injected. Must not be the bootstrap loader.public UsingReflection(ClassLoader classLoader, @MaybeNull ProtectionDomain protectionDomain)
ClassLoader and a default PackageDefinitionStrategy where the
 injection of existent classes does not trigger an error.classLoader - The ClassLoader into which new class definitions are to be injected. Must not be the bootstrap loader.protectionDomain - The protection domain to apply during class definition.public UsingReflection(ClassLoader classLoader, @MaybeNull ProtectionDomain protectionDomain, PackageDefinitionStrategy packageDefinitionStrategy, boolean forbidExisting)
ClassLoader and ProtectionDomain.classLoader - The ClassLoader into which new class definitions are to be injected.Must  not be the bootstrap loader.protectionDomain - The protection domain to apply during class definition.packageDefinitionStrategy - The package definer to be queried for package definitions.forbidExisting - Determines if an exception should be thrown when attempting to load a type that already exists.public boolean isAlive()
true if this injector is available on the current VM.public Map<String,Class<?>> injectRaw(Map<? extends String,byte[]> types)
types - The types to load via injection.public static boolean isAvailable()
true if this class injection is available.public static ClassInjector ofSystemClassLoader()
Copyright © 2014–2023. All rights reserved.