我正在整理Java反射的一些箔和示例代码。 这是我使用代理的天真示例代码:
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
interface MyInterface { void foo(); }
class Handler implements InvocationHandler {
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("Called for : " + proxy);
System.out.println("Called with: " + method);
return null;
}
}
public class ProxyExample {
public static void main(String args[]) {
Handler handler = new Handler();
MyInterface proxied = (MyInterface) Proxy.newProxyInstance(MyInterface.class.getClassLoader(),
new Class[] { MyInterface.class }, handler);
proxied.foo();
}
}
你能猜出会发生什么吗?
Exception in thread "main" java.lang.StackOverflowError
at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:422)
at java.lang.StringBuilder.append(StringBuilder.java:136)
at java.lang.StringBuilder.<init>(StringBuilder.java:113)
at xxx..Handler.invoke(ProxyExample.java:15)
当我评论出第一个打印输出时,我得到:
Called with: public abstract void xxx.MyInterface.foo()
知道导致递归和堆栈溢出的原因是什么?
答案 0 :(得分:4)
System.out.println("Called for : " + proxy);
将调用代理的toString()
方法,再次调用Handler,导致无限递归。