优秀如你,代码世界因你绽放光彩!!!

java.lang.StackOverflowError

一对多查询时报错:

StackOverflowError  :StackOverflowError在程序栈空间耗尽时抛出,通常是深度递归导致。

就是说:方法在调用时,无限成立且循环执行,消耗内存,报错栈内存溢出。

在一对多关联表两个对象的toString方法重写之后,应用程序递归太深了,所以发生了堆栈溢出。

解决:

1....去除一个表中的toString()方法。(这是最简单的方法,但是这样打印出来的结果只是订单的内存地址,不易查看)

A表需要B表的对象,B表同时需要A表的对象,才能获得成立,这是条件,所以会无限成立调用,直至内存耗尽。

去除toSting这样可以避免互相调用,改变永恒成立。

2....去除一个表中的toString()方法中的另一张表的属性对象(既:属性变量cities)。

 改前::::
@Override
    public String toString() {
        return "Flighties{" +
                "id=" + id +
                ", flightNo='" + flightNo + '\'' +
                ", arriveDate=" + arriveDate +
                ", cities=" + cities +
                '}';
    }

改为::::
 @Override
    public String toString() {
        return "Flighties{" +
                "id=" + id +
                ", flightNo='" + flightNo + '\'' +
                ", arriveDate=" + arriveDate +
                '}';
    }

 

3....用其中的一个对象去设置另一个对象值为空null。

 1  @Test
 2     @Transactional //事务 必须加
 3     public void test01(){
 4         //根据id 查询
 5         Cities one = citiesDao.findOne(1l);
 6 
 7         Set<Flighties> flighties = one.getFlighties();
 8         for(Flighties flight:flighties){
 9             flight.setCities(null);//提前终止,不会无限递归下去
10             System.out.println(flight);
11         }
12     }

 

posted @ 2019-08-21 20:39  Hi~Hi  阅读(757)  评论(0编辑  收藏  举报
学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!wished for you successed !!!