应用场景
设置了登录拦截器,除去登录和获取验证码请求之后,其他请求一律拦截。
问题描述
登录之后,点击角色管理页面报错,无法获取角色数据。
前端报错
后端报错
日志显示拦截器抛出了异常,
2024-05-27 10:18:44 [ERROR] org.springframework.web.servlet.HandlerExecutionChain HandlerInterceptor.afterCompletion threw exception
java.lang.StackOverflowError: null
at com.syt.spzx.utils.AuthContextUtil.remove(AuthContextUtil.java:28)
at com.syt.spzx.utils.AuthContextUtil.remove(AuthContextUtil.java:28)
at com.syt.spzx.utils.AuthContextUtil.remove(AuthContextUtil.java:28)
at com.syt.spzx.utils.AuthContextUtil.remove(AuthContextUtil.java:28)
at com.syt.spzx.utils.AuthContextUtil.remove(AuthContextUtil.java:28)
……
解决方法
java.lang.StackOverflowError: null
栈内存溢出
都已经给你写明白出错位置了,直接点进去找到对应的就行了。首先检查一下有没有出现死循环,bingo…!属于一击必中了,remove方法反复调用自己,ctrl进不去。
// 删除数据
public static void remove(){
remove();
}
正确引用remove()方法!!!
// 删除数据
public static void remove(){
threadLocal.remove();
}
呵呵呵,被自己蠢笑了(╹▽╹)
总结
1. 栈溢出错误是什么?
在Java中,当一个程序运行时,每当调用一个方法,JVM就会在调用栈上添加一个栈帧(stack frame)以存储局部变量和操作指令。
通常,内存中有足够的空间来处理正常的方法调用,但如果有大量递归调用或深层次的方法调用嵌套,那么JVM的调用栈可能会耗尽,这时就会抛出StackOverflowError异常。
简单来说,如果一个线程所需用到栈的大小>配置允许最大的栈大小或者死循环会导致该异常。
2. StackOverflowError通常有几个常见的原因
- 🚩无限递归: 当一个方法不断地调用自己,而没有设定一个明确的退出条件时,这种情况
最常见
。 - 深层次递归: 递归调用深度太深,超过了JVM默认的栈大小限制。
- 大量嵌套方法调用: 即使没有递归,方法之间互相调用也可能产生非常深的调用链。
- 大量的局部变量: 每个栈帧都包含其对应方法的局部变量,如果这些变量过多或占用空间太大,也可能触发栈溢出。
3. StackOverflowError的解决思路
- 检查递归调用: 确认所有的递归方法都有正确的基础情况并且能够最终终止递归。
- 优化算法: 尝试将递归算法改写为迭代算法,减少调用栈的使用。
- 调整JVM栈大小: 如果问题不在于代码本身,可以尝试增加JVM的调用栈大小。
- 减少局部变量的使用: 尽量减少方法内部的局部变量声明,特别是大型数据结构。
参考文章链接:https://blog.csdn.net/FMC_WBL/article/details/135330379