public class MethodProxy
extends java.lang.Object
Enhancer
pass this object to the
registered MethodInterceptor
objects when an intercepted method is invoked. It can
be used to either invoke the original method, or call the same method on a different
object of the same type.Modifier and Type | Class and Description |
---|---|
private static class |
MethodProxy.CreateInfo |
private static class |
MethodProxy.FastClassInfo |
Modifier and Type | Field and Description |
---|---|
private MethodProxy.CreateInfo |
createInfo |
private MethodProxy.FastClassInfo |
fastClassInfo |
private java.lang.Object |
initLock |
private Signature |
sig1 |
private Signature |
sig2 |
Modifier | Constructor and Description |
---|---|
private |
MethodProxy() |
Modifier and Type | Method and Description |
---|---|
static MethodProxy |
create(java.lang.Class c1,
java.lang.Class c2,
java.lang.String desc,
java.lang.String name1,
java.lang.String name2)
For internal use by
Enhancer only; see the org.springframework.cglib.reflect.FastMethod class
for similar functionality. |
static MethodProxy |
find(java.lang.Class type,
Signature sig)
Return the
MethodProxy used when intercepting the method
matching the given signature. |
(package private) FastClass |
getFastClass() |
Signature |
getSignature()
Return the signature of the proxied method.
|
(package private) FastClass |
getSuperFastClass() |
int |
getSuperIndex()
Return the
org.springframework.cglib.reflect.FastClass method index
for the method used by invokeSuper(java.lang.Object, java.lang.Object[]) . |
java.lang.String |
getSuperName()
Return the name of the synthetic method created by CGLIB which is
used by
invokeSuper(java.lang.Object, java.lang.Object[]) to invoke the superclass
(non-intercepted) method implementation. |
private static FastClass |
helper(MethodProxy.CreateInfo ci,
java.lang.Class type) |
private void |
init() |
java.lang.Object |
invoke(java.lang.Object obj,
java.lang.Object[] args)
Invoke the original method, on a different object of the same type.
|
java.lang.Object |
invokeSuper(java.lang.Object obj,
java.lang.Object[] args)
Invoke the original (super) method on the specified object.
|
private Signature sig1
private Signature sig2
private MethodProxy.CreateInfo createInfo
private final java.lang.Object initLock
private volatile MethodProxy.FastClassInfo fastClassInfo
public static MethodProxy create(java.lang.Class c1, java.lang.Class c2, java.lang.String desc, java.lang.String name1, java.lang.String name2)
Enhancer
only; see the org.springframework.cglib.reflect.FastMethod
class
for similar functionality.private void init()
private static FastClass helper(MethodProxy.CreateInfo ci, java.lang.Class type)
public Signature getSignature()
public java.lang.String getSuperName()
invokeSuper(java.lang.Object, java.lang.Object[])
to invoke the superclass
(non-intercepted) method implementation. The parameter types are
the same as the proxied method.public int getSuperIndex()
org.springframework.cglib.reflect.FastClass
method index
for the method used by invokeSuper(java.lang.Object, java.lang.Object[])
. This index uniquely
identifies the method within the generated proxy, and therefore
can be useful to reference external metadata.getSuperName()
FastClass getFastClass()
FastClass getSuperFastClass()
public static MethodProxy find(java.lang.Class type, Signature sig)
MethodProxy
used when intercepting the method
matching the given signature.type
- the class generated by Enhancersig
- the signature to matchjava.lang.IllegalArgumentException
- if the Class was not created by Enhancer or does not use a MethodInterceptorpublic java.lang.Object invoke(java.lang.Object obj, java.lang.Object[] args) throws java.lang.Throwable
obj
- the compatible object; recursion will result if you use the object passed as the first
argument to the MethodInterceptor (usually not what you want)args
- the arguments passed to the intercepted method; you may substitute a different
argument array as long as the types are compatiblejava.lang.Throwable
- the bare exceptions thrown by the called method are passed through
without wrapping in an InvocationTargetException
MethodInterceptor#intercept
public java.lang.Object invokeSuper(java.lang.Object obj, java.lang.Object[] args) throws java.lang.Throwable
obj
- the enhanced object, must be the object passed as the first
argument to the MethodInterceptorargs
- the arguments passed to the intercepted method; you may substitute a different
argument array as long as the types are compatiblejava.lang.Throwable
- the bare exceptions thrown by the called method are passed through
without wrapping in an InvocationTargetException
MethodInterceptor#intercept