weixin_42356882
2010-03-24 01:32
浏览 184
已采纳

java.lang.StackOverflowError

用spring aop拦截参数,参数可能是对象,于是我重载了对象的tostring方法,用反射取出对象的属性值代码如下:
public class BaseBean {
/**
*
*/
private static final long serialVersionUID = 1L;

public String toString() {
String s = "";
try {

s = getPropertyString(this);//获取对象属性值
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return s;
}
public String getPropertyString(Object entityName) throws Exception {
    String methodname=null;
    Method method = null;
Class c = entityName.getClass();
Field field[] = c.getDeclaredFields();
StringBuffer sb = new StringBuffer();
for (Field f : field) {
    if(!f.getName().equals("serialVersionUID" )){
        methodname=f.getName().substring(0, 1).toUpperCase()+ f.getName().substring(1);//取得方法名称
        method=c.getMethod("get"+methodname);//取得方法
sb.append(method.invoke(entityName));//调用方法并把得到的值相加


    }

}
    entityName=null;
System.gc();//销毁对象
return sb.toString();
}

直接测试的时候没问题,测试代码:
public class Test {
public static void main(String[] args){
for(int i=0;i<10;i++){
User user=new User();
user.setUsername("yyy");
user.setAddress("zzz");
System.out.println(user.toString());
}
}

}
但是放在AOP中就出现java.lang.StackOverflowError异常,提示是Field field[] =c.getDeclaredFields();sb.append(method.invoke(entityName));这两行出错;
还有个奇怪的信息:at java.util.AbstractCollection.toString(Unknown Source)
at org.hibernate.collection.PersistentSet.toString(PersistentSet.java:310)
不知道关hibernate什么事情,spring拦截代码如下:
public void charcheck(JoinPoint joinpoint){
Object[] obj=joinpoint.getArgs();
System.out.println(obj[0].toString());
}

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • wanghaolovezlq 2010-03-24 10:32
    已采纳

    抛出异常当然就中断了线程,你还可以设置线程异常处理器

    public void setUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh)设置该线程由于未捕获到异常而突然终止时调用的处理程序。
    通过明确设置未捕获到的异常处理程序,线程可以完全控制它对未捕获到的异常作出响应的方式。如果没有设置这样的处理程序,则该线程的 ThreadGroup 对象将充当其处理程序。

    参数:
    eh - 用作该线程未捕获到的异常处理程序的对象。如果为 null,则该线程没有明确的处理程序。

    这种方式适用于你还要去异常处理的情况,好像还蛮符合你现在的情况

    点赞 打赏 评论
  • wanghaolovezlq 2010-03-24 08:32

    你一定是通过hibernate查询出的数据,然后再aop的吧,
    PersistentSet这玩意是hibernate内部封装集合数据的方式

    点赞 打赏 评论
  • wanghaolovezlq 2010-03-24 08:45

    现在的现象就是说明已经由hibernate返回的数据导致的,不然不可能出现hibernate封装的set集合,

    你粘全点代码与配置信息

    点赞 打赏 评论
  • wanghaolovezlq 2010-03-24 09:49

    就是hibernate的对象之间的关联关系造成的。

    阻止线程运行,得到要阻止的线程引用,调用它的interrupt()方法,就能中断线程

    点赞 打赏 评论

相关推荐 更多相似问题