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 }
学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!wished for you successed !!!