使用cglib的错误

今天用cglib实现一个简单 程序,代码如下。但是竟然产生StackOverflowError错误:

     package org.yu.useCGLIB.simple;

import java.lang.reflect.Method;

import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import net.sf.cglib.proxy.Enhancer;
public class AroundAvice implements MethodInterceptor {
 private static AroundAvice aroundAvice=new AroundAvice();
 private AroundAvice(){
  
 }
 public static Object newInstance(Class clazz){
  Enhancer enhancer=new Enhancer();
  enhancer.setSuperclass(clazz);
  enhancer.setCallback(aroundAvice);
  
  return enhancer.create();
 }

 public Object intercept(Object arg0, Method arg1, Object[] arg2,
   MethodProxy arg3) throws Throwable {
  
  System.out.println(arg0);
  System.out.println(arg1);
  System.out.println(arg3);
  System.out.println(arg2);
 
  return null;
 }
 public static void main(String args[]){
  MethodInterface me=(MethodInterface)newInstance(MethodInterfaceImp.class);
  me.say();
 }

}

出现以下错误:

      Exception in thread "main" java.lang.StackOverflowError
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)
 at org.yu.useCGLIB.simple.AroundAvice.intercept(AroundAvice.java:24)
 at org.yu.useCGLIB.simple.MethodInterfaceImp$$EnhancerByCGLIB$$ee4216f6.toString(<generated>)
 at java.lang.String.valueOf(Unknown Source)
 at java.io.PrintStream.print(Unknown Source)
 at java.io.PrintStream.println(Unknown Source)

 

按照cglib的官方网站的trace写法,能解决如下错误,但还不知原因:

代码如下:

package org.yu.useCGLIB.simple;

import java.lang.reflect.Method;

import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import net.sf.cglib.proxy.Enhancer;
public class AroundAvice implements MethodInterceptor {
 private static AroundAvice aroundAvice=new AroundAvice();
 private AroundAvice(){
  
 }
 public static Object newInstance(Class clazz){
  Enhancer enhancer=new Enhancer();
  enhancer.setSuperclass(clazz);
  enhancer.setCallback(aroundAvice);
  
  return enhancer.create();
 }

 public Object intercept(Object arg0, Method arg1, Object[] arg2,
   MethodProxy arg3) throws Throwable {
  
  
  // TODO Auto-generated method stub
  for(int i=0;i<arg2.length;i++){
  if( arg0 == arg2[i])
            System.out.println("this");
        else
           System.out.println(arg2[i]);
  }
  System.out.println(arg1);
  Object retValFromSuper = null;
  retValFromSuper=arg3.invokeSuper(arg0,arg2);
  if( arg0 == retValFromSuper)
           System.out.println("this");
        else System.out.println(retValFromSuper);
     //System.out.println("调用 "+arg1.getName()+" 方法前");
  //Object retValFromSuper=arg3.invokeSuper(arg0,arg2);
  //System.out.println("调用 "+arg1.getName()+" 方法后");
  return null;//retValFromSuper;
 }
 public static void main(String args[]){
  MethodInterface me=(MethodInterface)newInstance(MethodInterfaceImp.class);
  me.say();
 }

}

有如下输出结果:

public void org.yu.useCGLIB.simple.MethodInterfaceImp.say()
Hello world
null

显然问题解决了但还是找不到原因:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值