我在写一个返回Token的时候,报出了 StackOverflowError的异常。
但是,我看了下,里面逻辑,不知道是怎么会报这个问题呢。
下面是代码片段
Token tokenCheck = tokenService.queryTokenOfUserId(userEntity.getId());
if (flag) {
//生成Token令牌
String token = UUID.randomUUID() + "";//UUID生成名字符串
Token tokenObject = new Token();
tokenObject.setToken(token);
tokenObject.setUserId(userEntity.getId());
tokenObject.setUserName(uName);
//存入Redis数据库,没有Redis暂时存入Mysql,加个时间限定,可以不加吧?
//还没有加密
String saturnNum = userEntity.getSaturnNum();//土星号
int userId = userEntity.getId();//用户Id
String avatar = userEntity.getAvatar();//用户头像
jsonObject.put("userId", userId);
jsonObject.put("userName", uName);
jsonObject.put("userToken", token);
jsonObject.put("saturnNum", saturnNum);
jsonObject.put("avatar", avatar);
//如果没有token
if ("".equals(tokenCheck) || tokenCheck == null) {
tokenService.addToken(tokenObject);
jsonObject.put(Consts.CODE, 1);
jsonObject.put(Consts.MSG, "登录成功");
jsonObject.put(Consts.DATA, jsonObject);
return jsonObject;
} else {
tokenService.updateToken(tokenObject);//根据用户名,查询出用户,再得到id,去删除对应token
jsonObject.put(Consts.CODE, 1);
jsonObject.put(Consts.MSG, "登录成功");
jsonObject.put(Consts.DATA, jsonObject);
return jsonObject;
}
}
jsonObject.put(Consts.CODE, 0);
jsonObject.put(Consts.MSG, "用户名或密码错误");
jsonObject.put(Consts.DATA, null);
return jsonObject;
26行和32行的jsonObject.put(Consts.DATA, jsonObject);
的代码,可以自己放自己进去?我不太明白Java的编程
是不是因为函数调用层次太深,动态申请空间使用之后没有释放,数组访问越界或指针非法访问
tokenService.queryTokenOfUserId
、tokenService.updateToken
这两个方法源码发出来你可以看看参考https://blog.csdn.net/danpu0978/article/details/107276621
https://blog.csdn.net/weixin_36194037/article/details/78871468
https://www.jb51.net/article/210195.htm
出现StackOverflowError错误的原因有两个,一个是栈溢出,另外一个原因就是函数调用栈太深了,也就是说代码中存在循环调用方法而无法退出的情况,你把你的代码精简一下,就比如说:在这个代码块中 jsonObject.put(Consts.CODE, 1); 这句话出现了两次,你完全可以只写一句。把代码精简后再试试看
把运行得dump文件弄出来,分析一下,可以借助第三方工具
报错 StackOverflowError 的堆栈信息贴出来一下。。初步怀疑 Token tokenCheck = tokenService.queryTokenOfUserId(userEntity.getId()); 这个错误就是堆栈溢出,一般是死循环,要么是数据过载了