类 DefaultContextLoadTimeWeaver
- java.lang.Object
- org.springframework.context.weaving.DefaultContextLoadTimeWeaver
- 所有已实现的接口:
Aware
,BeanClassLoaderAware
,DisposableBean
,LoadTimeWeaver
public class DefaultContextLoadTimeWeaver extends Object implements LoadTimeWeaver, BeanClassLoaderAware, DisposableBean
DefaultLoadTimeWeaver
bean for use in an application context, decorating an automatically detected internalLoadTimeWeaver
.Typically registered for the default bean name "
loadTimeWeaver
"; the most convenient way to achieve this is Spring's<context:load-time-weaver>
XML tag.This class implements a runtime environment check for obtaining the appropriate weaver implementation: As of Spring 4.0, it detects Oracle WebLogic 10, GlassFish 3, Tomcat 6, 7 and 8, JBoss AS 5, 6 and 7, IBM WebSphere 7 and 8,
Spring's VM agent
, and anyClassLoader
supported by Spring'sReflectiveLoadTimeWeaver
.- 从以下版本开始:
- 2.5
- 作者:
- Juergen Hoeller, Ramnivas Laddad, Costin Leau
- 另请参阅:
ConfigurableApplicationContext.LOAD_TIME_WEAVER_BEAN_NAME
构造器概要
构造器 构造器 说明 DefaultContextLoadTimeWeaver()
DefaultContextLoadTimeWeaver(ClassLoader beanClassLoader)
方法概要
所有方法 实例方法 具体方法 修饰符和类型 方法 说明 void
addTransformer(ClassFileTransformer transformer)
Add aClassFileTransformer
to be applied by thisLoadTimeWeaver
.protected LoadTimeWeaver
createServerSpecificLoadTimeWeaver(ClassLoader classLoader)
void
destroy()
Invoked by the containingBeanFactory
on destruction of a bean.ClassLoader
getInstrumentableClassLoader()
Return aClassLoader
that supports instrumentation through AspectJ-style load-time weaving based on user-definedClassFileTransformers
.ClassLoader
getThrowawayClassLoader()
Return a throwawayClassLoader
, enabling classes to be loaded and inspected without affecting the parentClassLoader
.void
setBeanClassLoader(ClassLoader classLoader)
Callback that supplies the beanclass loader
to a bean instance.
构造器详细资料
DefaultContextLoadTimeWeaver
public DefaultContextLoadTimeWeaver()
DefaultContextLoadTimeWeaver
public DefaultContextLoadTimeWeaver(ClassLoader beanClassLoader)
方法详细资料
setBeanClassLoader
public void setBeanClassLoader(ClassLoader classLoader)
从接口复制的说明:BeanClassLoaderAware
Callback that supplies the beanclass loader
to a bean instance.Invoked after the population of normal bean properties but before an initialization callback such as
InitializingBean's
InitializingBean.afterPropertiesSet()
method or a custom init-method.- 指定者:
setBeanClassLoader
在接口中BeanClassLoaderAware
- 参数:
classLoader
- the owning class loader; may benull
in which case a defaultClassLoader
must be used, for example theClassLoader
obtained viaClassUtils.getDefaultClassLoader()
createServerSpecificLoadTimeWeaver
protected LoadTimeWeaver createServerSpecificLoadTimeWeaver(ClassLoader classLoader)
destroy
public void destroy()
从接口复制的说明:DisposableBean
Invoked by the containingBeanFactory
on destruction of a bean.- 指定者:
destroy
在接口中DisposableBean
addTransformer
public void addTransformer(ClassFileTransformer transformer)
从接口复制的说明:LoadTimeWeaver
Add aClassFileTransformer
to be applied by thisLoadTimeWeaver
.- 指定者:
addTransformer
在接口中LoadTimeWeaver
- 参数:
transformer
- theClassFileTransformer
to add
getInstrumentableClassLoader
public ClassLoader getInstrumentableClassLoader()
从接口复制的说明:LoadTimeWeaver
Return aClassLoader
that supports instrumentation through AspectJ-style load-time weaving based on user-definedClassFileTransformers
.May be the current
ClassLoader
, or aClassLoader
created by thisLoadTimeWeaver
instance.- 指定者:
getInstrumentableClassLoader
在接口中LoadTimeWeaver
- 返回:
- the
ClassLoader
which will expose instrumented classes according to the registered transformers
getThrowawayClassLoader
public ClassLoader getThrowawayClassLoader()
从接口复制的说明:LoadTimeWeaver
Return a throwawayClassLoader
, enabling classes to be loaded and inspected without affecting the parentClassLoader
.Should not return the same instance of the
ClassLoader
returned from an invocation ofLoadTimeWeaver.getInstrumentableClassLoader()
.- 指定者:
getThrowawayClassLoader
在接口中LoadTimeWeaver
- 返回:
- a temporary throwaway
ClassLoader
; should return a new instance for each call, with no existing state