本文目录一览:
- java.lang.reflect.Field 这是干什么的?
- 为什么会产生java.lang.reflect.invocationtargetexception
- 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();
}
我们发现当传递来的参数 e
为 InvocationTargetException
的时候弹出的对话框中的消息是空的,查看 InvocationTargetException
的源码得知 InvocationTargetException
并没有覆盖 getMessage
方法,所以消息当然是空的了。我们需要调用 InvocationTargetException
的 getTargetException
方法得到要被包装的异常,这个异常才是真正我们需要的异常。修改代码如下所示:
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
对象,可以得到 construct
、method
这些具体的类定义的细节。
类的细节就是构造函数、普通函数、静态函数、字段成员等等,就对应了 java.lang.reflect
下的那一堆类。