调用toString方法会StackOverflowError的原因和解决方案

小编 2026-06-04 阅读:899 评论:0
今天遇到一个问题,调用一个实体类的toString方法直接就StackOverflowError(栈溢出)了。 java.lang.StackOverflowError at sun.reflect....

今天遇到一个问题,调用一个实体类的toString方法直接就StackOverflowError(栈溢出)了。

java.lang.StackOverflowError
	at sun.reflect.GeneratedMethodAccessor223.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:84)
	at com.xxx.entity.LoanServiceInstitutionEntity_$$_jvst7df_21.toString(LoanServiceInstitutionEntity_$$_jvst7df_21.java)
	at java.lang.String.valueOf(String.java:2994)
	at java.lang.StringBuilder.append(StringBuilder.java:131)
	at java.util.AbstractCollection.toString(AbstractCollection.java:462)
	at org.hibernate.collection.internal.PersistentBag.toString(PersistentBag.java:510)
	at java.lang.String.valueOf(String.java:2994)
	at java.lang.StringBuilder.append(StringBuilder.java:131)
	at com.xxx.entity.CooperativeInstitutionEntity.toString(CooperativeInstitutionEntity.java:23)
	at java.lang.String.valueOf(String.java:2994)
	at java.lang.StringBuilder.append(StringBuilder.java:131)
	at com.xxx.entity.LoanServiceInstitutionEntity.toString(LoanServiceInstitutionEntity.java:24)
	at sun.reflect.GeneratedMethodAccessor223.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:84)
	at com.xxx.entity.LoanServiceInstitutionEntity_$$_jvst7df_21.toString(LoanServiceInstitutionEntity_$$_jvst7df_21.java)

第一眼就看到了JavassistLazyInitializer以为是懒加载问题,后来想懒加载也不会StackOverflowError啊。

再仔细看发现调用有点问题:

LoanServiceInstitutionEntity.toString()

    ->CooperativeInstitutionEntity.toString()

        ->LoanServiceInstitutionEntity.toString()

            ->CooperativeInstitutionEntity.toString()

            ....

这两个实体类循环toString()陷入死循环了,可是我只调用了一次LoanServiceInstitutionEntity.toString()。

点到这两实体类看发现他们相互关联了,代码如下:

@Data
@Entity
@DynamicInsert
@DynamicUpdate
@Table(name = \"t_cooperative_institution\")
public class CooperativeInstitutionEntity implements Cloneable, Serializable {
    @OneToMany(mappedBy = \"cooperativeInstitutionEntity\", cascade = { CascadeType.ALL }, fetch = FetchType.LAZY)
    private List<LoanServiceInstitutionEntity> loanServiceInstitutionEntityList = new ArrayList<>();
...
}


@Data
@Entity
@DynamicInsert
@DynamicUpdate
@Table(name = \"t_loan_service_institution\"})
public class LoanServiceInstitutionEntity implements Cloneable, Serializable {
    @ManyToOne(optional = false, fetch = FetchType.LAZY)
    @JoinColumn(name = \"cooperative_institution_id\", insertable = false, updatable = false, foreignKey = @ForeignKey(name = \"null\", value = ConstraintMode.NO_CONSTRAINT))
    private CooperativeInstitutionEntity cooperativeInstitutionEntity;
...
}

然后lombok的@Data注解会自动生成包含所有非静态字段的toString()方法。

所以调用LoanServiceInstitutionEntity的toString()方法会去get cooperativeInstitutionEntity属性,

然后促发hibernate懒加载机制去数据库查询数据返回cooperativeInstitutionEntity,

接着在调用cooperativeInstitutionEntity.toString()时又去get 里面的loanServiceInstitutionEntityList属性...

因为两边数据有关联,所以会无限循环下去。

 

解决方案:给不需要加到toString的熟悉加上@ToString.Exclude注解或者@ToString(exclude = {\"需要排除的属性名\"})

版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

上一篇:tcp客户端socket 下一篇:tcp服务端socket
热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表