美文网首页
怎样排查 java.lang.ArrayStoreExcepti

怎样排查 java.lang.ArrayStoreExcepti

作者: 十毛tenmao | 来源:发表于2021-05-18 15:18 被阅读0次

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

问题表现

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

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

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可以看出来

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打断点后,可以发现如下错误
java.lang.TypeNotPresentException: Type com.***.MessageSender not present

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

参考

相关文章

  • 怎样排查 java.lang.ArrayStoreExcepti

    项目运行时,有时候会遇到异常java.lang.ArrayStoreException,导致进程启动失败,但是从异...

  • vSphere 性能优化方法 & 故障排错方法及工具总结(二)

    故障排查方法、工具总结 一、vSphere 故障排查思想 1 、故障排查思维逻辑 故障排查涉及到整体的排错方法论,...

  • vsphere 故障排查

    vsphere 故障排查 vsphere 故障排查 1 vSphere 排错思想1.1 故障排查逻辑1.2 常规故...

  • 春天……

    不管怎样,春天总会到来! 即使依然很冷,小草还是如约发芽了,向阳的花儿也开了! 疫情,排查,核酸,密接……这些伴随...

  • 【实践】golang pprof 实战-CPU,heap,all

    目录 前言实验准备获取“炸弹”使用 pprof排查 CPU 占用过高排查内存占用过高排查频繁内存回收排查协程泄露排...

  • AP无法上线AC

    【免费视频】RAP无法上线排查 【详细故障排查】如需了解更加详细的排查过程,请点击我进入

  • 机修

    油泵不工作电路排查 先排查保险线路:先用试灯全部排查,上面有中文标注就直接查管油路的,上面是你...

  • 集群健康度分析

    排查步骤

  • 排查

    哈哈哈

  • 排查

    现在工作群里会不定期地发布疫情排查的群公告,而且你一定要确认,因为上面要收集全体工作人员确认的图像。 ...

网友评论

      本文标题:怎样排查 java.lang.ArrayStoreExcepti

      本文链接:https://www.haomeiwen.com/subject/ppxyjltx.html