- 浏览: 81018 次
- 性别:
- 来自: 成都
最新评论
-
cfczdws:
唉,还有好多要学~~
css 文档流 父级对象 同级对象 -
chinalitianwu:
很有帮助 对于我这样的菜鸟来说
ServletContext与ApplicationContext -
gaoddhan:
讲的不错
hashcode 和equal -
bestree007:
execute()不是回调函数吗?
回调函数 -
talin2010:
真的很详细
JSP/Servlet编码设置详解
转自:http://summernight.iteye.com/blog/359843
一直以来感觉“java反射机制”是个很神秘,至少是我一时半会搞不懂的东西。。。也因为这种一直报着害怕的感觉没敢深入学习,可是就是前几天因为看到“大话设计模式 之 小菜编程成长记”中讲的设计模式中讲到java反射,使得我不得不好好的学习下java反射,真正静下心来学习过后才发现原来java反射没有我想象的那么可怕,原来java已经给写好了反射的API,只要调用一切都可以得到。。。。
首先什么是java反射?
java反射是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其modifiers(诸如public, static等等)、superclass(例如Object)、实现之interfaces(例如Cloneable),也包括fields和methods的所有信息,并可于运行时改变fields内容或唤起methods。
下面我就通过例子来把我了解的java反射里的应用给罗列出来。。
Java代码
/*
* 获得Class的方法有两种
* 一、.getClass()
* 二、Class.forName()
* */
/*
* Class cla = "com.pac.Provider".getClass();
* System.out.println(cla.getPackage().getName());
* System.out.println(cla.getSuperclass().getName());
* System.out.println(cla.getInterfaces()[0].getName());
* Field[] fid = cla.getDeclaredFields();
* for(Object o:fid){
* Field fd = (Field)o;
* System.out.println(fd.getName());
* }
* 刚才是这样写的,输出的结果居然是:
* java.lang
* java.lang.Object
* java.io.Serializable
* value
* offset
* count
* hash
* serialVersionUID
* serialPersistentFields
* CASE_INSENSITIVE_ORDER
* 顿时超级郁闷。怎么我的父类和定义的属性都对不上,经过朋友的帮助突然毛塞顿开,原来"com.pac.Provider"这样写其实就是
* 对String的取得Class所得的数据,其实人家根据没有取错啊。。。只是我用错了。。。
* */
Class cla = Provider.class;
Class cla_s = null;
try {
cla_s = Class.forName("com.pac.Provider");//静态方式获取
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(cla.getPackage().getName());//获取Provider的包路径名称
System.out.println(cla.getSuperclass().getName());//获取Provider的父类名称
Class[] interfaces = cla.getInterfaces();
for(Object o:interfaces){
Class is =(Class)o;
System.out.println(is.getName());//获取Provider的所有实现的接口的名称
}
Field[] fid = cla.getDeclaredFields();//获取Provider自身定义的属性名称,不论 public 或private 或其它类型皆可获得
for(Object o:fid){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Field[] fid_1 = cla.getFields();//获取Provider及父类定义的属性名称,只能获得public类型的属性
for(Object o:fid_1){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Method[] med = cla.getDeclaredMethods();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:med){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Method[] med_d = cla.getMethods();//得到Provider及其父类以及父类的父类(以此类推)的所有的public方法,当然子类重写父类的方法的情况下只显示一次。
for(Object o:med_d){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Constructor[] con = cla.getDeclaredConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("Constructor:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
Constructor[] con_c = cla.getConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con_c){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("getConstructors:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
/*
* 获得Class的方法有两种
* 一、.getClass()
* 二、Class.forName()
* */
/*
* Class cla = "com.pac.Provider".getClass();
* System.out.println(cla.getPackage().getName());
* System.out.println(cla.getSuperclass().getName());
* System.out.println(cla.getInterfaces()[0].getName());
* Field[] fid = cla.getDeclaredFields();
* for(Object o:fid){
* Field fd = (Field)o;
* System.out.println(fd.getName());
* }
* 刚才是这样写的,输出的结果居然是:
* java.lang
* java.lang.Object
* java.io.Serializable
* value
* offset
* count
* hash
* serialVersionUID
* serialPersistentFields
* CASE_INSENSITIVE_ORDER
* 顿时超级郁闷。怎么我的父类和定义的属性都对不上,经过朋友的帮助突然毛塞顿开,原来"com.pac.Provider"这样写其实就是
* 对String的取得Class所得的数据,其实人家根据没有取错啊。。。只是我用错了。。。
* */
Class cla = Provider.class;
Class cla_s = null;
try {
cla_s = Class.forName("com.pac.Provider");//静态方式获取
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(cla.getPackage().getName());//获取Provider的包路径名称
System.out.println(cla.getSuperclass().getName());//获取Provider的父类名称
Class[] interfaces = cla.getInterfaces();
for(Object o:interfaces){
Class is =(Class)o;
System.out.println(is.getName());//获取Provider的所有实现的接口的名称
}
Field[] fid = cla.getDeclaredFields();//获取Provider自身定义的属性名称,不论 public 或private 或其它类型皆可获得
for(Object o:fid){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Field[] fid_1 = cla.getFields();//获取Provider及父类定义的属性名称,只能获得public类型的属性
for(Object o:fid_1){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Method[] med = cla.getDeclaredMethods();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:med){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Method[] med_d = cla.getMethods();//得到Provider及其父类以及父类的父类(以此类推)的所有的public方法,当然子类重写父类的方法的情况下只显示一次。
for(Object o:med_d){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Constructor[] con = cla.getDeclaredConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("Constructor:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
Constructor[] con_c = cla.getConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con_c){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("getConstructors:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
反射 的另三个动态性质: (1) 运行时生成 instances , (2) 执 行期唤起 methods , (3) 运行时改动 fields 。
Java代码
try {
cla.newInstance();//实例化这个类
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
try {
cla.newInstance();//实例化这个类
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
Java代码
try {
Class[] ptypes = new Class[2];
ptypes[0] = Object.class;
ptypes[1] = String.class;
Method mm = cla.getDeclaredMethod("copy", ptypes);
Provider pp = (Provider)cla.newInstance();
Object ags[] = new Object[2];
ags[0] = new Object();
ags[1] = new String("Hello,world");
mm.invoke(pp, ags);
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
Class[] ptypes = new Class[2];
ptypes[0] = Object.class;
ptypes[1] = String.class;
Method mm = cla.getDeclaredMethod("copy", ptypes);
Provider pp = (Provider)cla.newInstance();
Object ags[] = new Object[2];
ags[0] = new Object();
ags[1] = new String("Hello,world");
mm.invoke(pp, ags);
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Java代码
//运行时变更fields内容
try {
Field code = cla.getDeclaredField("code");
Field name = cla.getDeclaredField("name");
Provider pp = (Provider)cla.newInstance();
name.set(pp, "nameaaa");
code.set(pp, "code1");
System.out.println("code:"+pp.getCode());
System.out.println("name:"+pp.getName());
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchFieldException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//运行时变更fields内容
try {
Field code = cla.getDeclaredField("code");
Field name = cla.getDeclaredField("name");
Provider pp = (Provider)cla.newInstance();
name.set(pp, "nameaaa");
code.set(pp, "code1");
System.out.println("code:"+pp.getCode());
System.out.println("name:"+pp.getName());
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchFieldException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
在什么环境下使用 java反射?
我想java反射在java的开源项目中真的用的好多,比如:spring的ioc,JDBC 的 classForName(),strut2中的配置文件的读取应该也是反射,等等。。。而且反射使得编程特别灵活,只要在运行状态下,你知道这个类的名称就可以得到你想到的任何东西,当然包括实例化。。。
一直以来感觉“java反射机制”是个很神秘,至少是我一时半会搞不懂的东西。。。也因为这种一直报着害怕的感觉没敢深入学习,可是就是前几天因为看到“大话设计模式 之 小菜编程成长记”中讲的设计模式中讲到java反射,使得我不得不好好的学习下java反射,真正静下心来学习过后才发现原来java反射没有我想象的那么可怕,原来java已经给写好了反射的API,只要调用一切都可以得到。。。。
首先什么是java反射?
java反射是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其modifiers(诸如public, static等等)、superclass(例如Object)、实现之interfaces(例如Cloneable),也包括fields和methods的所有信息,并可于运行时改变fields内容或唤起methods。
下面我就通过例子来把我了解的java反射里的应用给罗列出来。。
Java代码
/*
* 获得Class的方法有两种
* 一、.getClass()
* 二、Class.forName()
* */
/*
* Class cla = "com.pac.Provider".getClass();
* System.out.println(cla.getPackage().getName());
* System.out.println(cla.getSuperclass().getName());
* System.out.println(cla.getInterfaces()[0].getName());
* Field[] fid = cla.getDeclaredFields();
* for(Object o:fid){
* Field fd = (Field)o;
* System.out.println(fd.getName());
* }
* 刚才是这样写的,输出的结果居然是:
* java.lang
* java.lang.Object
* java.io.Serializable
* value
* offset
* count
* hash
* serialVersionUID
* serialPersistentFields
* CASE_INSENSITIVE_ORDER
* 顿时超级郁闷。怎么我的父类和定义的属性都对不上,经过朋友的帮助突然毛塞顿开,原来"com.pac.Provider"这样写其实就是
* 对String的取得Class所得的数据,其实人家根据没有取错啊。。。只是我用错了。。。
* */
Class cla = Provider.class;
Class cla_s = null;
try {
cla_s = Class.forName("com.pac.Provider");//静态方式获取
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(cla.getPackage().getName());//获取Provider的包路径名称
System.out.println(cla.getSuperclass().getName());//获取Provider的父类名称
Class[] interfaces = cla.getInterfaces();
for(Object o:interfaces){
Class is =(Class)o;
System.out.println(is.getName());//获取Provider的所有实现的接口的名称
}
Field[] fid = cla.getDeclaredFields();//获取Provider自身定义的属性名称,不论 public 或private 或其它类型皆可获得
for(Object o:fid){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Field[] fid_1 = cla.getFields();//获取Provider及父类定义的属性名称,只能获得public类型的属性
for(Object o:fid_1){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Method[] med = cla.getDeclaredMethods();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:med){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Method[] med_d = cla.getMethods();//得到Provider及其父类以及父类的父类(以此类推)的所有的public方法,当然子类重写父类的方法的情况下只显示一次。
for(Object o:med_d){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Constructor[] con = cla.getDeclaredConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("Constructor:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
Constructor[] con_c = cla.getConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con_c){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("getConstructors:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
/*
* 获得Class的方法有两种
* 一、.getClass()
* 二、Class.forName()
* */
/*
* Class cla = "com.pac.Provider".getClass();
* System.out.println(cla.getPackage().getName());
* System.out.println(cla.getSuperclass().getName());
* System.out.println(cla.getInterfaces()[0].getName());
* Field[] fid = cla.getDeclaredFields();
* for(Object o:fid){
* Field fd = (Field)o;
* System.out.println(fd.getName());
* }
* 刚才是这样写的,输出的结果居然是:
* java.lang
* java.lang.Object
* java.io.Serializable
* value
* offset
* count
* hash
* serialVersionUID
* serialPersistentFields
* CASE_INSENSITIVE_ORDER
* 顿时超级郁闷。怎么我的父类和定义的属性都对不上,经过朋友的帮助突然毛塞顿开,原来"com.pac.Provider"这样写其实就是
* 对String的取得Class所得的数据,其实人家根据没有取错啊。。。只是我用错了。。。
* */
Class cla = Provider.class;
Class cla_s = null;
try {
cla_s = Class.forName("com.pac.Provider");//静态方式获取
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(cla.getPackage().getName());//获取Provider的包路径名称
System.out.println(cla.getSuperclass().getName());//获取Provider的父类名称
Class[] interfaces = cla.getInterfaces();
for(Object o:interfaces){
Class is =(Class)o;
System.out.println(is.getName());//获取Provider的所有实现的接口的名称
}
Field[] fid = cla.getDeclaredFields();//获取Provider自身定义的属性名称,不论 public 或private 或其它类型皆可获得
for(Object o:fid){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Field[] fid_1 = cla.getFields();//获取Provider及父类定义的属性名称,只能获得public类型的属性
for(Object o:fid_1){
Field fd = (Field)o;
System.out.println(fd.getName());
}
Method[] med = cla.getDeclaredMethods();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:med){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Method[] med_d = cla.getMethods();//得到Provider及其父类以及父类的父类(以此类推)的所有的public方法,当然子类重写父类的方法的情况下只显示一次。
for(Object o:med_d){
Method fd = (Method)o;
System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
}
Constructor[] con = cla.getDeclaredConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("Constructor:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
Constructor[] con_c = cla.getConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
for(Object o:con_c){
Constructor fd = (Constructor)o;
TypeVariable[] tv = fd.getTypeParameters();
String para = "";
for(Object otv:tv){
TypeVariable v = (TypeVariable)otv;
para += v.getName()+",";
}
para = para.length()==0?"":para.substring(0, para.length()-1);
System.out.println("getConstructors:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
}
反射 的另三个动态性质: (1) 运行时生成 instances , (2) 执 行期唤起 methods , (3) 运行时改动 fields 。
Java代码
try {
cla.newInstance();//实例化这个类
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
try {
cla.newInstance();//实例化这个类
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
Java代码
try {
Class[] ptypes = new Class[2];
ptypes[0] = Object.class;
ptypes[1] = String.class;
Method mm = cla.getDeclaredMethod("copy", ptypes);
Provider pp = (Provider)cla.newInstance();
Object ags[] = new Object[2];
ags[0] = new Object();
ags[1] = new String("Hello,world");
mm.invoke(pp, ags);
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
Class[] ptypes = new Class[2];
ptypes[0] = Object.class;
ptypes[1] = String.class;
Method mm = cla.getDeclaredMethod("copy", ptypes);
Provider pp = (Provider)cla.newInstance();
Object ags[] = new Object[2];
ags[0] = new Object();
ags[1] = new String("Hello,world");
mm.invoke(pp, ags);
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Java代码
//运行时变更fields内容
try {
Field code = cla.getDeclaredField("code");
Field name = cla.getDeclaredField("name");
Provider pp = (Provider)cla.newInstance();
name.set(pp, "nameaaa");
code.set(pp, "code1");
System.out.println("code:"+pp.getCode());
System.out.println("name:"+pp.getName());
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchFieldException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//运行时变更fields内容
try {
Field code = cla.getDeclaredField("code");
Field name = cla.getDeclaredField("name");
Provider pp = (Provider)cla.newInstance();
name.set(pp, "nameaaa");
code.set(pp, "code1");
System.out.println("code:"+pp.getCode());
System.out.println("name:"+pp.getName());
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchFieldException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
在什么环境下使用 java反射?
我想java反射在java的开源项目中真的用的好多,比如:spring的ioc,JDBC 的 classForName(),strut2中的配置文件的读取应该也是反射,等等。。。而且反射使得编程特别灵活,只要在运行状态下,你知道这个类的名称就可以得到你想到的任何东西,当然包括实例化。。。
发表评论
-
java浅克隆和深克隆的定义
2011-02-27 17:42 1150转自: http://wxg6203.iteye.co ... -
Java 异常类别
2010-07-15 21:34 893java中的所有异常都继承java.lang.Throwabl ... -
回调函数
2010-05-17 11:14 1120转自: http://summerbell.itey ... -
深入探讨类加载器
2010-04-20 11:33 751转自:http://www.ibm.com/developer ... -
Java内部类可见性
2010-04-20 10:27 1073转自:http://zhangjunhd.blog.51cto ... -
Hashtable和HashMap的区别
2010-04-20 10:14 1285转自:http://edu.codepub.com/2009/ ... -
hashcode 和equal
2010-04-20 10:10 1265转自:http://lawrenst.iteye.com/bl ... -
运算符
2010-04-20 09:42 985转自:http://zangweiren.itey ... -
多线程
2010-04-20 09:40 873转自:http://zangweiren.iteye.com/ ... -
继承、多态、重载和重写
2010-04-20 09:37 981转自:http://zangweiren.itey ... -
基本类型
2010-04-20 09:33 1133转自:http://zangweiren.iteye.com/ ... -
日期和时间的处理
2010-04-19 22:54 810转自:http://zangweiren.iteye.com/ ... -
String杂谈
2010-04-19 18:51 744转自:http://zangweiren.iteye.com/ ... -
传了值还是传了引用
2010-04-19 18:40 638转自:http://zangweiren.iteye.com/ ... -
final finally和 finalize的区别
2010-04-19 18:32 990转自:http://zangweiren.iteye.com/ ... -
到底创建了几个String对象
2010-04-19 18:15 738转自:http://zangweiren.iteye.com/ ... -
类的初始化顺序
2010-04-19 17:42 448转自: http://zangweiren.iteye.com ... -
path,classpath,java_home设置详解
2010-04-19 10:31 3594转自于: http://blog.csdn.net/yinyu ...
相关推荐
Java反射是Java编程语言中的一个重要特性,它允许程序在运行时动态地获取类的信息并操作类的对象。在Java中,反射机制提供了强大的能力,包括在运行时检查类的结构、创建对象实例、调用方法以及访问和修改字段值。...
Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建对象、获取类...
Java反射机制是Java语言提供的一种强大功能,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类是java.lang.Class,它代表了运行时的类信息。通过Class对象,我们...
在本文中,我们将深入探讨如何使用Java反射来获取并执行某个特定的方法。 首先,我们需要了解Java反射的基本概念。`java.lang.Class`类是反射的核心,它代表了Java中的每一个类。我们可以通过以下方式获取到一个...
### Java反射性能测试分析 #### 引言 Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的...
### Java反射机制总结 #### 反射的概念与起源 反射的概念最早由Smith于1982年提出,指的是程序能够访问、检测并修改其自身状态或行为的能力。这一概念的提出迅速引起了计算机科学领域的广泛关注,并在之后的研究中...
Java反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...
### Java反射机制详解 #### 一、概述 Java反射机制是一种强大的编程技术,它允许运行时检查类的信息并操作对象的内部结构。本篇将基于Sun公司的官方文档《Java™ Core Reflection API and Specification》(1997年...
### 反射实例—JAVA反射机制 #### 一、反射概念及原理 反射在计算机科学领域,特别是程序设计中,是指程序有能力访问、检测和修改其自身的结构和行为。这一概念最早由Smith于1982年提出,并迅速应用于各种编程语言...
### Java反射机制详解 #### 一、什么是Java反射? Java反射是Java编程语言的一个特性,它允许运行时检查和操作程序结构(类、字段、方法等)。反射的主要用途包括但不限于:动态实例化对象、访问私有成员、调用...
Java反射是Java语言提供的一种强大的动态类型特性,它允许程序在运行时检查类、接口、字段和方法的信息,并且能够动态地创建对象和调用方法。这个能力使得开发者可以突破静态类型的束缚,实现一些在编译时期无法完成...
Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有高度的灵活性,尤其在处理框架、插件系统以及元数据驱动...
### Java反射机制详解 #### 一、反射的基本概念与历史背景 反射的概念最早由Smith在1982年提出,其核心思想是程序有能力访问、检测甚至修改自身的状态和行为。这种能力一经提出,迅速成为了计算机科学领域的研究...
### Java反射机制与NoSuchMethodException详解 在Java编程中,反射是一种强大的机制,允许程序在运行时检查和修改自身结构和行为。然而,当开发者尝试使用反射调用一个不存在的方法时,便会遇到`java.lang....
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建动态代理等。...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在给定的“利用java反射将json字符串转成对象”的主题中,我们将深入探讨如何借助反射机制将JSON...
### Java反射机制详解 #### 一、什么是Java反射机制? Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的...
Java反射机制是Java编程语言中的一个强大工具,它允许程序在运行时检查并操作类、接口、字段和方法等对象。在"北大青鸟java反射机制"的学习资料中,我们将会深入探讨这一核心特性。 首先,我们要理解反射的核心概念...
### Java反射机制详解 #### 一、引言 在Java编程语言中,反射(Reflection)是一种强大的工具,它允许程序在运行时访问类的信息,并能够动态地创建对象、调用方法以及获取字段值等。这种能力对于框架设计、代码...