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