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