时间:2021-05-19
如下所示:
////////////////// Load.javapackage org.bromon.reflect;import java.util.ArrayList;import java.util.List;public class Load implements Operator { @Override public List<?> act(List<?> params) { // TODO Auto-generated method stub List<String> result=new ArrayList<String>(); result.add(new String("加载成功")); return result; }}/////////////////// Operator.javapackage org.bromon.reflect;import java.util.*;public interface Operator { public List<?> act(List<?> params);}/////////////Store.javapackage org.bromon.reflect;import java.util.ArrayList;import java.util.List;public class Store implements Operator { @Override public List<?> act(List<?> params) { // TODO Auto-generated method stub List<String> result=new ArrayList<String>(); result.add(new String("Store")); return result; }}///////////////Success.javapackage org.bromon.reflect;import java.util.List;import java.util.ArrayList;public class Success implements Operator { @Override public List<?> act(List<?> params) { // TODO Auto-generated method stub List<String> result=new ArrayList<String>(); result.add(new String("操作成功")); return result; }}////////////////////////TestReflect.javapackage org.bromon.reflect;import java.io.FileInputStream;import java.lang.reflect.Method;import java.util.ArrayList;import java.util.Properties;import java.util.List;public class TestReflect { private String loadProtocal(String header) { String result = null; try { Properties prop = new Properties(); FileInputStream fis = new FileInputStream("emp.properties"); prop.load(fis); result = prop.getProperty(header); fis.close(); } catch (Exception e) { System.out.println(e); } return result; } // 针对消息作出响应,利用反射导入对应的类 public String response(String header, String content) { String result = null; String s = null; try { /* * 导入属性文件emp.properties,查询header所对应 * * 的类的名字 通过反射机制动态加载匹配的类,所有的类都 * * 被Operator接口隔离 可以通过修改属性文件、添加新的类(继 * * 承MsgOperator接口)来扩展协议 */ s = "org.bromon.reflect." + this.loadProtocal(header); // 加载类 Class<?> c = Class.forName(s); // 创建类的事例 Operator mo = (Operator) c.newInstance(); // 构造参数列表 Class<?> params[] = new Class[1]; params[0] = Class.forName("java.util.List"); // 查询act方法 Method m = c.getMethod("act", params); List<String> args = new ArrayList<String>(); args.add(content); // 调用方法并且获得返回 Object returnObject = m.invoke(mo, args); List<?> list=(List<?>)returnObject; System.out.println(list.get(0)); } catch (Exception e) { System.out.println("Handler-response:" + e); } return result; } public static void main(String args[]) { TestReflect tr = new TestReflect(); tr.response("2000", "消息内容"); }}以上就是小编为大家带来的java 利用java反射机制动态加载类的简单实现的全部内容了,希望对大家有所帮助,多多支持~
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java反射机制与动态代理,使得Java更加强大,Spring核心概念IoC、AOP就是通过反射机制与动态代理实现的。1Java反射示例:Useruser=ne
1.概述JDK动态代理是利用java反射机制生成一个实现接口的匿名类,在调用具体方法前调用InvocationHandler来处理Cglib动态代理是利用asm
概述之前在了解Spring的类加载机制的时候,了解了java的反射机制。但是,我对反射理解一直不深。也一直有点疑惑:Spring为什么利用反射创建对象?直接ne
Java反射机制一、什么是反射机制简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,那么就可以通过反射机制来获得类的所有
本文实例讲述了Java反射机制原理与用法。分享给大家供大家参考,具体如下:Java反射机制Reflection(反射)是被视为动态语言的关键,反射机制允许程序在