【报错】StackOverflow问题定位和解决

本文记录了一次StackOverflow错误排查过程,该问题源于一个闭环的循环调用导致的栈溢出错误。通过分析日志,定位到getFullColumnName方法与appendWhereString方法之间的循环调用,并给出了相应的解决方案。

记录今日遇到的StackOverflow问题:

1.stackoverflow最可能出现的问题就是循环调用、递归

2.打印日志

2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
2022-11-08 16:39:26.408 [http-nio-8080-exec-5] INFO  [89912737961] com.bonc.ds.utils.LogUtil [?:?] - Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.StackOverflowError

根据日志中调用推断出循环调用方法,并且排除递归,根据如下日志雷伊看出

问题是循环调用getFullColumnName方法导致,在getFullColumnName方法中调用了appendWhereString,appendWhereString方法中又重复调用getFullColumnName。导致闭环栈溢出

Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
Caused by: java.lang.StackOverflowError: null
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1408)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.toSelectSqlNoAlias(SQLBuilder.java:579)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.appendFilterSelect(SQLBuilder.java:941)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.toFilterString(SQLBuilder.java:752)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendComplicatedFilterString(SQLBuilder.java:651)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.appendWhereString(SQLBuilder.java:389)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)
	at com.*【手动打码】*.getFullColumnName(SQLBuilder.java:1448)

 3.修改调用逻辑

此次问题出在一个方法来回调用闭环,导致栈溢出。

修改逻辑

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值