开发者社区> 冬至饮雪> 正文

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

简介:   今天在整合ssh项目中,碰到一个异常,当我提交购物车数据到订单时,浏览器报了一个这样的异常.   当时,我就吓坏了.尼玛,这不是内存溢出了吗?吓得我赶紧去检查了每一个有遍历语句的代码,结果没有发现一个死循环,折腾了两个多小时,最后终于发现了问题,简直让人抓狂,原因竟然是我在实体类,order(订单),orderItem(订单项)中都重写了ToString()方法.
+关注继续查看

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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Java基础-19总结IO流,异常try…catch,throws,File类
1:异常(理解) (1)程序出现的不正常的情况。 (2)异常的体系 Throwable |--Error 严重问题,我们不处理。 |--Exception |--RuntimeException 运行期异常,我们需要修正代码 |--非RuntimeException 编译期异常,必须处理的,否则程序编译不通过
1442 0
hibernate4整合spring3出现java.lang.NoClassDefFoundError: [Lorg/hibernate/engine/FilterDefinition;
1.错误日志: nested exception is java.lang.NoClassDefFoundError: [Lorg/hibernate/engine/FilterDefinition;: java.
880 0
Tomcat服务器java.lang.IllegalArgumentException异常
Tomcat服务器java.lang.IllegalArgumentException异常
146 0
Java 集合整理大全
TreeSet, LinkedHashSet and HashSet 的区别 TreeSet的主要功能用于排序,它是无序的(插入顺序)LinkedHashSet的主要功能用于保证FIFO即有序的集合(先进先出)HashSet只是通用的存储数据的集合共同点三者都不是线程安全的,如果要使用线程安全可以collections.
1113 0
java.lang.NoClassDefFoundError: * : Landroid/support/v7/gridlayout/R$styleable 异常终极解决办法
该问题解决办法适用于任何类似问题。 问题的标准异常描述为:java.lang.NoClassDefFoundError: Failed resolution of: Landroid/support/v7/gridlayout/R$styleable 今天由于项目需要,想在...
908 0
+关注
116
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载