javalangreflect,javalangreflectinvocation null

发布时间:2022-11-19

本文目录一览:

  1. java.lang.reflect.Field 这是干什么的?
  2. 为什么会产生java.lang.reflect.invocationtargetexception
  3. java.lang中的Class类,与java.lang.reflect包中的construct、method等有什么联系和区别?

java.lang.reflect.Field 这是干什么的?

java.lang.reflect包,主要提供了一些“反射”的类。也就是经常会听到的反射机制常用到的一些类。 java.lang.reflect.Field主要是用于反射类的字段。 反射经常用于工具类的开发,或中间件的开发。

为什么会产生java.lang.reflect.invocationtargetexception

InvocationTargetException 是一种包装由调用方法或构造方法所抛出异常的受查异常。这个异常并不是Eclipse插件开发特有的,而是标准JDK中的,它定义在 java.lang.reflect包下。在进行Java开发的时候很少会接触到这个异常,不过在进行Eclipse插件开发中则不同,很多API都声明抛出此类异常,因此必须对此异常进行处理。 例如,我们开发一个方法用来统一处理异常:

private static void handleException(Exception e)
{
    MessageDialog.openError(Activator.getDefault().getWorkbench()
        .getDisplay().getActiveShell(), "error", e.getMessage());
    e.printStackTrace();
}

我们发现当传递来的参数 eInvocationTargetException 的时候弹出的对话框中的消息是空的,查看 InvocationTargetException 的源码得知 InvocationTargetException 并没有覆盖 getMessage 方法,所以消息当然是空的了。我们需要调用 InvocationTargetExceptiongetTargetException 方法得到要被包装的异常,这个异常才是真正我们需要的异常。修改代码如下所示:

private static void handleException(Exception e)
{
    String msg = null;
    if (e instanceof InvocationTargetException)
    {
        Throwable targetEx = ((InvocationTargetException) e)
            .getTargetException();
        if (targetEx != null)
        {
            msg = targetEx.getMessage();
        }
    } else
    {
        msg = e.getMessage();
    }
    MessageDialog.openError(Activator.getDefault().getWorkbench()
        .getDisplay().getActiveShell(), "error", msg);
    e.printStackTrace();
}

java.lang中的Class类,与java.lang.reflect包中的construct、method等有什么联系和区别?

有一些联系,谈不上区别。他们是独立的类,各自有自己的功能。 你每定义一个类(产生一个 .java 文件),系统运行的时候,加载 .java 文件,系统就多了一个类的定义。 系统里面保存类的定义的方式就是用 java.lang.Class。 也就是说,任何类都有一个对应的 Class 对象。

Class clz = String.class; // class静态字段就是该类的Class对象。

通过 Class 对象,可以得到 constructmethod 这些具体的类定义的细节。 类的细节就是构造函数、普通函数、静态函数、字段成员等等,就对应了 java.lang.reflect 下的那一堆类。