热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java中重写toString方法引发的StackOverflowError问题分析与解决

本文探讨了在Java应用中,由于对象间循环引用导致重写toString方法时出现StackOverflowError的具体情况,并提供了有效的解决方案。

在开发Java应用程序时,经常需要自定义类的toString方法来方便调试和日志记录。然而,不当的实现可能导致严重的性能问题,甚至程序崩溃。例如,在我的项目中有两个类:User和Role,它们之间存在多对一的关系。

在User类中,我重写了toString方法以提供详细的用户信息输出:

@Override
public String toString() {
return "User [userId=" + this.userId + ", profileName=" + this.profileName+ ", firstName=" + this.firstName + ", lastName=" + this.lastName+ ", email=" + this.email + ", socialEmail=" + this.socialEmail+ ", accountEnabled=" + this.accountEnabled + ", accountNOnExpired="+ this.accountNonExpired + ", accountNOnLocked=" + this.accountNonLocked+ ", country=" + this.country + ", role=" + this.role + "]";
}

同样地,在Role类中也实现了toString方法:

@Override
public String toString() {
return "Role [roleId=" + roleId + ", users=" + users + ", role=" + role
+ "]";
}

通过Hibernate框架从数据库查询用户详细信息时,遇到了一个问题。具体代码如下:

@SuppressWarnings("unchecked")
public User getUser(String name){
List userList = new ArrayList();
Query query = sessionFactory.getCurrentSession().createQuery("from User u where u.profileName = :name or u.socialEmail = :name");
query.setParameter("name", name);
userList = query.list();
if (userList.size() > 0)
return userList.get(0);
else
return null;
}

当执行到userList = query.list();这一行时,程序抛出了StackOverflowError异常,指出问题在于toString方法的调用。

异常堆栈信息如下:

java.lang.StackOverflowError
at java.lang.AbstractStringBuilder.ensureCapacityInternal(AbstractStringBuilder.java:113)
at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:415)
at java.lang.StringBuilder.append(StringBuilder.java:132)
at java.lang.StringBuilder.(StringBuilder.java:110)
at com.myapp.model.User.toString(User.java:189)
at java.lang.String.valueOf(String.java:2902)
at java.lang.StringBuilder.append(StringBuilder.java:128)
at java.util.AbstractCollection.toString(AbstractCollection.java:450)
at org.hibernate.collection.PersistentSet.toString(PersistentSet.java:310)
at java.lang.String.valueOf(String.java:2902)
at java.lang.StringBuilder.append(StringBuilder.java:128)
at com.myapp.model.Role.toString(Role.java:67)

进一步检查发现,异常发生在User类的toString方法的起始位置:at com.myapp.model.User.toString(User.java:189)

原因分析:在User类的toString方法中引用了Role对象,而在Role类的toString方法中又引用了User对象。这种双向引用导致了无限递归,即当尝试打印某个角色的所有用户时,每个用户的toString方法又会试图打印其关联的角色,从而形成循环。

解决方案:为了避免这种循环引用导致的堆栈溢出错误,可以在toString方法中添加逻辑判断,仅在必要时打印关联对象的信息。例如,可以通过设置标志位或使用其他策略来避免无限递归,确保每次调用toString时都能正确终止。


推荐阅读
  • 本文介绍了Android中常见的动画类型及其应用场景,通过具体的代码示例展示了如何在Activity跳转时添加平滑过渡效果,提升用户体验。 ... [详细]
  • 深入解析Java中的锁类型及其应用场景
    本文详细介绍了Java中常见的锁类型,包括乐观锁与悲观锁、独占锁与共享锁、互斥锁与读写锁、可重入锁、公平锁与非公平锁、分段锁、偏向锁、轻量级锁、重量级锁以及自旋锁。每种锁的特性、作用及适用场景均有所涉及。 ... [详细]
  • 软件项目管理实践——Jenkins持续集成与Maven、GitHub的应用
    本文详细介绍了如何利用Jenkins实现持续集成,以及Maven和GitHub在项目开发中的具体应用。包括环境搭建、工具安装、项目创建及代码管理等关键步骤。 ... [详细]
  • 本文介绍如何通过自定义控件LoadLayout实现ListView的上拉加载更多和下拉刷新功能。LoadLayout支持上拉加载,而下拉刷新则利用了android.support.v4.widget.SwipeRefreshLayout组件。 ... [详细]
  • 本文档详细介绍了Robot Framework的基础知识、安装配置方法及其实用技巧。从环境搭建到编写第一个测试用例,涵盖了一系列实用的操作指南和最佳实践。 ... [详细]
  • 框图|中将_DA14531 学习笔记经验总结
    框图|中将_DA14531 学习笔记经验总结 ... [详细]
  • 本人最近在学习python,在看了一些教程后,用python写了一个简单的云音乐播放器,下面把主要代码贴上来,其中用到了gi ... [详细]
  • 本文详细探讨了Scala中单例模式的实现方式,通过关键字object来模拟其他语言中的静态成员功能,同时介绍了伴生对象的概念及其应用场景。 ... [详细]
  • Django框架的使用教程mysql数据库[三]
    Django的数据库1.在Django_test下的view.py里面model定义模型fromdjango.dbimportmodels#Createyourmodelshere ... [详细]
  • 统计报表模板及其实现方法
    本文介绍两个实用的统计报表模板,并提供如何将这些静态模板转换为动态JSP页面的方法。同时,文中附上了详细的代码示例。 ... [详细]
  • 本文详细记录了《PHP与MySQL Web开发》第一章的学习心得,特别关注了PHP的基本构成元素、标记风格、编程注意事项及表单处理技巧等内容。 ... [详细]
  • 本文介绍了如何处理在使用 aiohttp 进行 HTTPS 请求时遇到的 SSL 证书验证错误,包括忽略证书验证和使用自定义证书的方法。 ... [详细]
  • 本文探讨了使用Lighttpd与FastCGI实现分布式部署的方法。通过在中心服务器上配置Lighttpd负责请求转发,同时在多个远程服务器上运行FastCGI进程来处理实际业务逻辑,从而提高系统的负载能力和响应速度。 ... [详细]
  • Shiro功能拓展:登录失败重试次数限制
    本文详细介绍了如何在Apache Shiro框架中实现对用户登录失败重试次数的限制,通过自定义密码匹配器来增强系统的安全性。该方法不仅能够有效防止暴力破解攻击,还能确保合法用户的账户安全。 ... [详细]
  • 一、数据更新操作DML语法中主要包括两个内容:查询与更新,更新主要包括:增加数据、修改数据、删除数据。其中这些操作是离不开查询的。1、增加数据语法:INSERTINTO表名称[(字 ... [详细]
author-avatar
我病态见不得你跟别人恩爱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有