Java代理示例是否正在创建堆栈溢出?

时间:2015-03-02 12:12:22

标签: java reflection

我正在整理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()

知道导致递归和堆栈溢出的原因是什么?

1 个答案:

答案 0 :(得分:4)

System.out.println("Called for : " + proxy);

将调用代理的toString()方法,再次调用Handler,导致无限递归。