前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >怎样排查 java.lang.ArrayStoreException

怎样排查 java.lang.ArrayStoreException

作者头像
十毛
发布2021-05-20 14:43:41
9590
发布2021-05-20 14:43:41
举报
文章被收录于专栏:用户1337634的专栏

项目运行时,有时候会遇到异常java.lang.ArrayStoreException,导致进程启动失败,但是从异常信息并不能直接看出来是什么原因。

问题表现

Spring Boot启动失败,错误异常栈如下:

代码语言:javascript
复制
java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy
    at java.lang.Class.createAnnotationData(Class.java:3521) [6 skipped]
    at java.lang.Class.annotationData(Class.java:3510)
    at java.lang.Class.getAnnotations(Class.java:3446)
    at org.springframework.core.type.StandardAnnotationMetadata.<init>(StandardAnnotationMetadata.java:70)

解决方法

  • 使用IDE的异常断点

异常断点设置

断点停在方法: sun.reflect.annotation.AnnotationParser#parseClassArray

代码语言:javascript
复制
private static Object parseClassArray(int var0, ByteBuffer var1, ConstantPool var2, Class<?> var3) {
    Class[] var4 = new Class[var0];
    boolean var5 = false;
    byte var6 = 0;

    for(int var7 = 0; var7 < var0; ++var7) {
        var6 = var1.get();
        if (var6 == 99) {
            //断点停在这里,其中var3是ZyMonitorAutoConfiguration类
            var4[var7] = (Class)parseClassValue(var1, var2, var3);
        } else {
            skipMemberValue(var6, var1);
            var5 = true;
        }
    }

    return var5 ? exceptionProxy(var6) : var4;
}

进入parseClassValue可以看出来

代码语言:javascript
复制
private static Object parseClassValue(ByteBuffer var0, ConstantPool var1, Class<?> var2) {
    int var3 = var0.getShort() & '\uffff';

    try {
        try {
            String var4 = var1.getUTF8At(var3);
            return parseSig(var4, var2);
        } catch (IllegalArgumentException var5) {
            return var1.getClassAt(var3);
        }
    } catch (NoClassDefFoundError var6) {
        return new TypeNotPresentExceptionProxy("[unknown]", var6);
    } catch (TypeNotPresentException var7) {
        return new TypeNotPresentExceptionProxy(var7.typeName(), var7.getCause());
    }
}
  • new TypeNotPresentExceptionProxy打断点后,可以发现如下错误
代码语言:javascript
复制
java.lang.TypeNotPresentException: Type com.***.MessageSender not present

从整个分析来说,是加载ZyMonitorAutoConfiguration的时候,没有找到类MessageSender。引入了对应的jar包后,问题解决

参考

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题表现
  • 解决方法
  • 参考
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档