ssh整合问题总结--运行项目时报java.lang.StackOverflowError(堆栈溢出)异常


  今天在整合ssh项目中,碰到一个异常,当我提交购物车数据到订单时,浏览器报了一个这样的异常.

  当时,我就吓坏了.尼玛,这不是内存溢出了吗?吓得我赶紧去检查了每一个有遍历语句的代码,结果没有发现一个死循环,折腾了两个多小时,最后终于发现了问题,简直让人抓狂,原因竟然是我在实体类,order(订单),orderItem(订单项)中都重写了ToString()方法.请看:

OrderItem.java:

package com.wang.shop.order.entity; import com.wang.shop.goods.entity.Goods; public class OrderItem { private Integer itemId;//订单项Id
    private Integer count;//商品数量
    private double total;//商品总价格 //订单项中的商品
    private Goods goods; //订单项所属的订单
    private Order order; //get/set方法省略
 @Override public String toString() { return "OrderItem [itemId=" + itemId + ", count=" + count + ", total="
                + total + ", goods=" + goods + ", order=" + order + "]"; } }

Order.java:

package com.wang.shop.order.entity; import java.util.Date; import java.util.HashSet; import java.util.Set; import com.wang.shop.user.entity.User; /** * 订单实体 * @author Administrator * */
public class Order { private Integer orderId;//订单Id 主键
    private String name;//收货人姓名
    private String address;//收货地址
    private String tel;//收货人电话
    private String postNum;//邮编
    private double allTotal; private Date orderDate;//订单创建日期 //订单所属的用户
    private  User user;//所有用户 外键 用户Id //订单里面的多个订单项
    private Set<OrderItem> orderItems=new HashSet<OrderItem>(); //get/set方法省略
 @Override public String toString() { return "Order [orderId=" + orderId + ", name=" + name + ", address="
                + address + ", tel=" + tel + ", postNum=" + postNum + ", allTotal=" + allTotal + ", orderDate=" + orderDate + ", user=" + user + ", orderItems=" + orderItems + "]"; } }

请注意!请注意!请注意! 在order类中我有一个set集合的属性,value正好是orderItem,而我又重写了OrderItem的ToString方法,于是乎,当代码执行:

  System.out.println("order:"+order);或者System.out.println("orderItem:"+orderItem);

  的时候,程序打印Order时,会打印OrderItem,打印OrderItem时,会打印Order,如果反复,无限循环~~~~~最后,啪叽,内存溢出.这个错误有点让人哭笑不得,第一次遇到,真是然我手足无措,立碑如此,切勿再犯.


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM