繁体   English   中英

Java中Reflected方法的异常stacktrace

[英]Exception stacktrace of Reflected method in Java

我通过反射调用方法,该方法引发异常。

但是当我通过

StackTraceElement[] elements = Thread.currentThread().getStackTrace();

我没有整个堆栈跟踪到反射的方法。 它仅在实现反射的我的方法之前获取堆栈跟踪。

反映的类完全在另一个项目中。

编辑:添加代码段

项目A

Class ReflectionImpl {

   public void callMethodsviaReflection{
     try{
              // Reflection code to call the method

         }catch(InvocationTargetException iTE){

           StringBuilder errorLogBuilder = new StringBuilder();
            errorLogBuilder.append(ex.toString());
            errorLogBuilder.append("\n");

            StackTraceElement[] elements = Thread.currentThread().getStackTrace();

             for (int i=0;i<elements.length;i++) {

                 errorLogBuilder.append((elements[i].toString()));
                 errorLogBuilder.append("\n");
             }

            System.out.println(errorLogBuilder.toString());
        }
    }
}

项目B- > 在Eclipse中引用项目A

Class ReflectedClass{

 List<String> nameList = null;

 public void reflectedMethod(){

     nameList.add("Hello");
    }      
}

在您致电的特定时间点:

StackTraceElement[] elements = Thread.currentThread().getStackTrace();

您的“反射调用”已经完成,这反映在您从调用返回的调用堆栈中。 听起来更像您想要的:

iTE.getCause().getStackTrace();

这将使您的调用堆栈达到并包括实际引发异常的方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM