关于JAVA反射机制 啥是JAVA反射机制,实际开发过程中用到不?都用在哪些地方,举个例子~~~~~~~~~~~~3QQQ 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 反射很重要。首先要理解什么是反射。在运行时阶段,当类已经被加载后,想访问类中的某些方法的信息,这时候就要用到反射。最简单的,你从配置文件中读取类的信息,都要通过反射。比如struts,就是通过反射手段来读取配置中path,然后加载所对应的action的。下面是一段代码,自己看看public class MyHiber { private static Connection con; private static Map<String, Integer> map; static { con = JdbcFactory.getConnection(); map = new HashMap<String, Integer>(); map.put("java.lang.Integer", 1); map.put("java.lang.String", 2); } public static List select(String sql, Class obj) throws SQLException, InstantiationException, IllegalAccessException, SecurityException, NoSuchMethodException, IllegalArgumentException, InvocationTargetException { List result = new ArrayList(); ResultSet rs = con.createStatement().executeQuery(sql); ResultSetMetaData md = rs.getMetaData(); while (rs.next()) { Object o = obj.newInstance(); for (int i = 1; i <= md.getColumnCount(); i++) { String column = md.getColumnName(i); String paraType = md.getColumnClassName(i); String methodName = "set" + createMethodName(column); Method method = null; switch (map.get(paraType)) { case 1: method = obj.getMethod(methodName, new Class[] { int.class }); method.invoke(o, rs.getInt(column)); break; case 2: method = obj.getMethod(methodName, new Class[] { java.lang.String.class }); method.invoke(o, rs.getString(column)); break; } } result.add(o); } return result; } private static String createMethodName(String name) { String methodName = null; String end = name.substring(1); char sta = name.charAt(0); methodName = Character.toString(Character.toUpperCase(sta)) + end; return methodName; }}PS:反射在实际开发中很常见。 正解,正是因为Java有了这用的机制,才使得我们很轻松的取得代理的应用! JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。Java反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。1. 得到某个对象的属性public Object getProperty(Object owner, String fieldName) throws Exception { Class ownerClass = owner.getClass(); Field field = ownerClass.getField(fieldName); Object property = field.get(owner); return property; }Class ownerClass = owner.getClass():得到该对象的Class。Field field = ownerClass.getField(fieldName):通过Class得到类声明的属性。Object property = field.get(owner):通过对象得到该属性的实例,如果这个属性是非公有的,这里会报IllegalAccessException。2. 得到某个类的静态属性 public Object getStaticProperty(String className, String fieldName) throws Exception { Class ownerClass = Class.forName(className); Field field = ownerClass.getField(fieldName); Object property = field.get(ownerClass); return property; }Class ownerClass = Class.forName(className) :首先得到这个类的Class。Field field = ownerClass.getField(fieldName):和上面一样,通过Class得到类声明的属性。Object property = field.get(ownerClass) :这里和上面有些不同,因为该属性是静态的,所以直接从类的Class里取。3. 执行某对象的方法 public Object invokeMethod(Object owner, String methodName, Object[] args) throws Exception { Class ownerClass = owner.getClass(); Class[] argsClass = new Class[args.length]; for (int i = 0, j = args.length; i < j; i++) { argsClass = args.getClass(); } Method method = ownerClass.getMethod(methodName, argsClass); return method.invoke(owner, args); }Class owner_class = owner.getClass() :首先还是必须得到这个对象的Class。5~9行:配置参数的Class数组,作为寻找Method的条件。Method method = ownerClass.getMethod(methodName, argsClass):通过Method名和参数的Class数组得到要执行的Method。method.invoke(owner, args):执行该Method,invoke方法的参数是执行这个方法的对象,和参数数组。返回值是Object,也既是该方法的返回值。4. 执行某个类的静态方法 public Object invokeStaticMethod(String className, String methodName, Object[] args) throws Exception { Class ownerClass = Class.forName(className); Class[] argsClass = new Class[args.length]; for (int i = 0, j = args.length; i < j; i++) { argsClass = args.getClass(); } Method method = ownerClass.getMethod(methodName, argsClass); return method.invoke(null, args); }基本的原理和实例3相同,不同点是最后一行,invoke的一个参数是null,因为这是静态方法,不需要借助实例运行。5. 新建实例 public Object newInstance(String className, Object[] args) throws Exception { Class newoneClass = Class.forName(className); Class[] argsClass = new Class[args.length]; for (int i = 0, j = args.length; i < j; i++) { argsClass = args.getClass(); } Constructor cons = newoneClass.getConstructor(argsClass); return cons.newInstance(args); }这里说的方法是执行带参数的构造函数来新建实例的方法。如果不需要参数,可以直接使用newoneClass.newInstance()来实现。Class newoneClass = Class.forName(className):第一步,得到要构造的实例的Class。第5~第9行:得到参数的Class数组。Constructor cons = newoneClass.getConstructor(argsClass):得到构造子。cons.newInstance(args):新建实例。6. 判断是否为某个类的实例 public boolean isInstance(Object obj, Class cls) { return cls.isInstance(obj); }7. 得到数组中的某个元素 public Object getByArray(Object array, int index) { return Array.get(array,index); } 为什么我输出写那么多东西 输出的 没那么多啊 ?有代码 帮忙看看 写了个java http多线程下载的程序, 发现有的网站图片可以下载,有的网站图片不可以下载, 为什么? Thread.sleep()睡眠的准确时间是括号里的指定时间吗? 使用JAVA如何与网页进行交互? 请教字符串转换的问题 救助,怎样判断一个文件的大小? 基础问题:关于事件 请问JBuilder7怎么编译我写好的java文件,用jb打开编译的选项为灰色? 问一道算法题 各个高手看看这个问题!本人第一次学习java所以要各位高手的帮助。。 多线程下对list里对象分组的实现模式 【新手学java】自定义包的问题
private static Map<String, Integer> map; static {
con = JdbcFactory.getConnection();
map = new HashMap<String, Integer>(); map.put("java.lang.Integer", 1);
map.put("java.lang.String", 2);
} public static List select(String sql, Class obj) throws SQLException,
InstantiationException, IllegalAccessException, SecurityException,
NoSuchMethodException, IllegalArgumentException,
InvocationTargetException { List result = new ArrayList(); ResultSet rs = con.createStatement().executeQuery(sql);
ResultSetMetaData md = rs.getMetaData(); while (rs.next()) {
Object o = obj.newInstance(); for (int i = 1; i <= md.getColumnCount(); i++) {
String column = md.getColumnName(i);
String paraType = md.getColumnClassName(i);
String methodName = "set" + createMethodName(column); Method method = null; switch (map.get(paraType)) {
case 1:
method = obj.getMethod(methodName,
new Class[] { int.class });
method.invoke(o, rs.getInt(column));
break; case 2:
method = obj.getMethod(methodName,
new Class[] { java.lang.String.class });
method.invoke(o, rs.getString(column));
break;
}
}
result.add(o);
}
return result;
} private static String createMethodName(String name) {
String methodName = null; String end = name.substring(1);
char sta = name.charAt(0);
methodName = Character.toString(Character.toUpperCase(sta)) + end; return methodName;
}
}PS:反射在实际开发中很常见。
Java反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。
1. 得到某个对象的属性public Object getProperty(Object owner, String fieldName) throws Exception {
Class ownerClass = owner.getClass();
Field field = ownerClass.getField(fieldName);
Object property = field.get(owner);
return property;
}
Class ownerClass = owner.getClass():得到该对象的Class。Field field = ownerClass.getField(fieldName):通过Class得到类声明的属性。Object property = field.get(owner):通过对象得到该属性的实例,如果这个属性是非公有的,这里会报IllegalAccessException。2. 得到某个类的静态属性 public Object getStaticProperty(String className, String fieldName)
throws Exception {
Class ownerClass = Class.forName(className);
Field field = ownerClass.getField(fieldName);
Object property = field.get(ownerClass);
return property;
}Class ownerClass = Class.forName(className) :首先得到这个类的Class。Field field = ownerClass.getField(fieldName):和上面一样,通过Class得到类声明的属性。Object property = field.get(ownerClass) :这里和上面有些不同,因为该属性是静态的,所以直接从类的Class里取。3. 执行某对象的方法 public Object invokeMethod(Object owner, String methodName, Object[] args) throws Exception {
Class ownerClass = owner.getClass();
Class[] argsClass = new Class[args.length];
for (int i = 0, j = args.length; i < j; i++) {
argsClass = args.getClass();
}
Method method = ownerClass.getMethod(methodName, argsClass);
return method.invoke(owner, args);
}
Class owner_class = owner.getClass() :首先还是必须得到这个对象的Class。5~9行:配置参数的Class数组,作为寻找Method的条件。Method method = ownerClass.getMethod(methodName, argsClass):通过Method名和参数的Class数组得到要执行的Method。method.invoke(owner, args):执行该Method,invoke方法的参数是执行这个方法的对象,和参数数组。返回值是Object,也既是该方法的返回值。4. 执行某个类的静态方法 public Object invokeStaticMethod(String className, String methodName,
Object[] args) throws Exception {
Class ownerClass = Class.forName(className);
Class[] argsClass = new Class[args.length];
for (int i = 0, j = args.length; i < j; i++) {
argsClass = args.getClass();
}
Method method = ownerClass.getMethod(methodName, argsClass);
return method.invoke(null, args);
}基本的原理和实例3相同,不同点是最后一行,invoke的一个参数是null,因为这是静态方法,不需要借助实例运行。5. 新建实例
public Object newInstance(String className, Object[] args) throws Exception {
Class newoneClass = Class.forName(className);
Class[] argsClass = new Class[args.length];
for (int i = 0, j = args.length; i < j; i++) {
argsClass = args.getClass();
}
Constructor cons = newoneClass.getConstructor(argsClass);
return cons.newInstance(args);
}这里说的方法是执行带参数的构造函数来新建实例的方法。如果不需要参数,可以直接使用newoneClass.newInstance()来实现。Class newoneClass = Class.forName(className):第一步,得到要构造的实例的Class。第5~第9行:得到参数的Class数组。Constructor cons = newoneClass.getConstructor(argsClass):得到构造子。cons.newInstance(args):新建实例。6. 判断是否为某个类的实例 public boolean isInstance(Object obj, Class cls) {
return cls.isInstance(obj);
}7. 得到数组中的某个元素
public Object getByArray(Object array, int index) {
return Array.get(array,index);
}