@HashCodeAndEqualsPlugin.Enhance public static class ClassInjector.UsingReflection extends ClassInjector.AbstractBase
| Modifier and Type | Class and Description | 
|---|---|
| protected static interface  | ClassInjector.UsingReflection.DispatcherA dispatcher for accessing a  ClassLoaderreflectively. | 
| protected static interface  | ClassInjector.UsingReflection.SystemA 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  ClassLoaderand a defaultProtectionDomainand a
 trivialPackageDefinitionStrategywhich does not trigger an error when discovering existent classes. | 
| UsingReflection(ClassLoader classLoader,
               ProtectionDomain protectionDomain)Creates a new injector for the given  ClassLoaderand a defaultPackageDefinitionStrategywhere 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  ClassLoaderandProtectionDomain. | 
| 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.