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,如果反复,无限循环~~~~~最后,啪叽,内存溢出.这个错误有点让人哭笑不得,第一次遇到,真是然我手足无措,立碑如此,切勿再犯.

原文地址:https://www.cnblogs.com/fingerboy/p/5319409.html