Java反射、动态加载(将java类名、方法、方法参数当做参数传递,执行方法)

Class c = null;
try {
c = Class.forName(classname);
} catch (Exception e) {
e.printStackTrace();
}
Object o = c.newInstance();//创建实例
classname由包名+类名组成,例如com.xx.logic.Testclass,一定要写包名全路径,否则有可能报错找不到类
Class c=Class.forName(classname);
c.newInstance()
Class c=Class.forName(classname);
c.getConstructor(String.class).newInstance(“Hello”);
getConstrutor里面为构造参数的Class类型,多个入参时传递Class[]数组
newInstance里为具体要传递的参数值
Method m = c.getMethod(methodname, paramstype);
m.invoke(o, params);
public static void main(String args[]) {
// new Eeflect().runMethod("util.hi", "test",new Object[]{});//不带参数的方法调用
// new Object[]{}
new Eeflect().runMethod_classinstance(new hi(), "test2", "1,int:2");//传递一个实例,去执行方法
new Eeflect().runMethod("util.hi", "add", new Object[]{"1", "2"});//带参数的方法调用,但是变量是固定的
new Eeflect().runMethod_classname("util.hi", "test", "");//不带参数的方法
new Eeflect().runMethod_classname("util.hi", "add", "1,2");//String类型的方法
new Eeflect().runMethod_classname("util.hi", "test2", "1,int:2");//String和int两种类型的方法
System.out.println(new Object[]{}.getClass() );
new Eeflect().runMethod_classname("util.hi", "print", "StringArrays:1、2、3");//不固定参数...的方法,使用数组传递 }
package util; import java.lang.reflect.Method;
import java.net.URLClassLoader;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map; //动态执行方法,但是不能调用方法的方法
//getparam_valueandetype():解析参数,分解为参数值和参数类型数组
//runMethod_classname():传递类名,自动实例化执行方法
//runMethod_classinstance():传递类实例,执行方法 public class Eeflect {
public Class getClass(String classname) {
// URLClassLoader classloader = (URLClassLoader) ClassLoader.getSystemClassLoader();
Class c = null;
try {
c = Class.forName(classname);
// c = classloader.loadClass(classname);
} catch (Exception e) {
e.printStackTrace();
}
return c;
} public Map getparam_valueandetype(String params) {//入参字符串,将其解析为参数class类型数组和参数值数组
//params使用英文逗号隔开,使用:分隔参数类型和值,例如abcd,int 1,test,int:2,StringArrays:1、2、3
Object[] paramlist = new Object[]{};//存储变量值
Class[] classtype = new Class[]{};//存储变量类型 Map result = new HashMap();
if (!params.equals("")) {//传递了参数params走这里
String[] paramslist_temp = params.split(",|,");
int num = paramslist_temp.length;
paramlist = new Object[num];
classtype = new Class[num];
for (int i = 0; i < num; i++) {
String[] param_type_value = paramslist_temp[i].toString().split(":");//判断参数是否有类型定义
if (param_type_value.length > 1) {
String param_type = param_type_value[0];
String param_value = param_type_value[1];
if (param_type.equalsIgnoreCase("int")) {
// System.out.println("value=" + param_value);
paramlist[i] = Integer.parseInt(param_value);
classtype[i] = int.class; } else if (param_type.equalsIgnoreCase("string")) {
paramlist[i] = param_value;
} else if (param_type.equalsIgnoreCase("stringarrays")) {
paramlist[i] = param_value.split("、");
classtype[i] = String[].class;
} else {
System.out.println("变量类型不支持,目前只支持int强转,当前变量的类型为:" + param_type);
return result;
}
} else { paramlist[i] = paramslist_temp[i];
classtype[i] = paramslist_temp[i].getClass();
}
}
} result.put("paramlist", paramlist);
result.put("classtype", classtype); return result;
} public boolean runMethod_classname(String classname, String methodname, String params) {//传递classname字符串,执行方法
boolean result = false;
Map paraminfo = this.getparam_valueandetype(params);
if (paraminfo == null) {
return result;
}
Object[] paramlist = (Object[]) paraminfo.get("paramlist");
Class[] classtype = (Class[]) paraminfo.get("classtype"); result=this.runMethod(classname, methodname, paramlist, classtype);
return result;
} public boolean runMethod(String classname, String methodname, Object[] params, Class[] paramstype) {//通过类名获得类实例,去执行方法
boolean result = false;
try {
Class c = this.getClass(classname);
if (c != null) {
Object o = c.newInstance();
Method m = c.getMethod(methodname, paramstype);
m.invoke(o, params);
result = true;
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
} public boolean runMethod_classinstance(Object classinstance, String methodname, String params) {//传递class实例,执行方法
boolean result = false;
Map paraminfo = this.getparam_valueandetype(params);
Object[] paramlist = new Object[]{};
Class[] classtype = new Class[]{};
if (paraminfo != null) {
paramlist = (Object[]) paraminfo.get("paramlist");
classtype = (Class[]) paraminfo.get("classtype");
} result = this.runMethod_hasclass(classinstance, methodname, paramlist, classtype); // if(!result){
// System.out.println("runMethod_classinstance失败了");
// }
return result;
} public boolean runMethod_hasclass(Object classinstance, String methodname, Object[] params, Class[] paramstype) {//通过类实例,去执行它的方法
boolean result = false;
try {
Class c = classinstance.getClass();
Method m = c.getMethod(methodname, paramstype);
m.invoke(classinstance, params);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
} public boolean runMethod(String classname, String methodname, Object[] params) {
boolean result = false;
try {
Class paramlist[] = null;
if (params != null) {//
int len = params.length;
paramlist = new Class[len];
for (int i = 0; i < len; ++i) {
paramlist[i] = params[i].getClass();
if (paramlist[i].toString().equals("class java.lang.Integer")) {
paramlist[i] = int.class;
}
}
} Class c = this.getClass(classname);
if (c != null) {
Object o = c.newInstance();
Method m = c.getMethod(methodname, paramlist);
m.invoke(o, params);
result = true;
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
Java反射、动态加载(将java类名、方法、方法参数当做参数传递,执行方法)的更多相关文章
- java反射动态加载类Class.forName();
1,所有的new出来的对象都是静态加载的,在程序编译的时候就会进行加载.而使用反射机制Class.forName是动态加载的,在运行时刻进行加载. 例子:直接上两个例子 public class Ca ...
- java反射--动态加载
Class.forName("类的全称") 1)不仅表示类的类类型,还表示了动态加载类 2)请区分编译,运行 3)编译时刻加载类是静态加载类,运行时刻加载类是动态加载类 比如下面: ...
- 透过现象看本质:Java类动态加载和热替换
摘要:本文主要介绍类加载器.自定义类加载器及类的加载和卸载等内容,并举例介绍了Java类的热替换. 最近,遇到了两个和Java类的加载和卸载相关的问题: 1) 是一道关于Java的判断题:一个类被首次 ...
- C# 利用反射动态加载dll
笔者遇到的一个问题,dll文件在客户端可以加载成功,在web端引用程序报错.解决方法:利用反射动态加载dll 头部引用加: using System.Reflection; 主要代码: Assembl ...
- .Net Core利用反射动态加载类库的方法(解决类库不包含Nuget依赖包的问题)
在.Net Framework时代,生成类库只需将类库项目编译好,然后拷贝到其他项目,即可引用或动态加载,相对来说,比较简单.但到了.Net Core时代,动态加载第三方类库,则稍微麻烦一些. 一.类 ...
- [改善Java代码]动态加载不适合数组
上一个建议解释了为什么要使用forName,本建议就说说哪些地方不适合使用动态加载. 如果forName要加载一个类,那它必须是一个类------8中基本类型就排除在外.它们不是一个具体的类. 其次它 ...
- Java的动态加载及其安全性问题
1.什么是动态加载 Class Loaders是动态加载Java类与Resource的一种机制.它支持Laziness,type-safe linkage,user-defined extensibi ...
- [转载] Java中动态加载jar文件和class文件
转载自http://blog.csdn.net/mousebaby808/article/details/31788325 概述 诸如tomcat这样的服务器,在启动的时候会加载应用程序中lib目录下 ...
- java动态加载jar包,并运行其中的类和方法
动态加载jar包,在实际开发中经常会需要用到,尤其涉及平台和业务的关系的时候,业务逻辑部分可以独立出去交给业务方管理,业务方只需要提供jar包,就能在平台上运行. 下面通过一个实例来直观演示: 第一: ...
- Java实现动态加载读取properties文件
问题: 当我们使用如下语句加载.properties时: ClassLoader classLoader = this.getClass().getClassLoader(); Properties ...
随机推荐
- 流程图工具Visual Paradigm for UML
- Maven上传jar包到私服
1.认证,在M2_HOME/conf/settings.xml配置用户名密码 <server> <id>releases</id> <username> ...
- jar 问题 : java.io.IOException: invalid header field
通过本文, 我们明白了什么是 jar的清单文件 MANIFEST.MF, 简单示例: E:\ws\Test\WEB-INF\classes>jar cvfm testCL.jar ListTes ...
- Centos7 搭建Gitlab服务器并配置项目全过程
https://blog.csdn.net/Abysscarry/article/details/79402695 gitlab与jenkins整合搭建 https://blog.csdn. ...
- 转载:“error LNK1169: 找到一个或多个多重定义的符号”的解决方法
转载来自:http://www.cnblogs.com/A-Song/archive/2012/03/23/2413782.html 问题描述如下: 有 三个源文件,A.h.B.cpp.C.cpp. ...
- Mybatis的回顾学习
<!--id:statementId resultType:查询结果集的数据类型 parameterType:查询的入参 --> <selectid="getUserByI ...
- 高级js--(面向对象js,arguments,闭包,自调)
1. Arguments对象 l检测参数个数 1.在函数代码中,使用特殊对象 arguments,开发者无需明确指出参数名,就能访问它们. function howManyArgs() { al ...
- Hadoop 3.0 安装
1. 下载Hadoop 3.0 http://mirrors.tuna.tsinghua.edu.cn/apache/hadoop/common/hadoop-3.0.0/hadoop-3. ...
- cordova- cordova-plugin-splashscreen启动页面和图标的设置
https://www.cnblogs.com/a418120186/p/5856371.html
- 给tkinter文本框添加右键菜单
给tkinter文本框添加右键菜单 需求:直接右键点击使用tkinter创建的文本框是不会弹出菜单的.我们需要实现右键点击tkinter框架下的Entry对象.Text对象后弹出右键菜单可复制.粘贴和 ...