网站首页 > java教程 正文
说明
参考内容:
1、反射机制,调用属性(静态&非静态);2、反射机制,调用构造方法(静态&非静态)。
getter/setter方法
定义一些方法来操作成员变量,每个方法都必须有一个有意义的名称,所以就有了getter-setter方法,getter-setter方法格式和写法都是固定的,所以只要有getter-setter方法就不用煞费心思的去想方法名称了,解决了起名字难问题。并且getter-setter方法还是程序员之间的一种规范,给属性赋值立刻就会想到getter-setter方法,降低了程序员之间的沟通成本。
代码案例
工具类:
import org.apache.commons.lang3.StringUtils;
import java.lang.reflect.Method;
import java.util.List;
public class ReflectCallMethod {
/**
* @param entryClass
* @param methodName
* @param <T>
* @return
*/
public static <T> T invokeForStatic(Class entryClass, String methodName) {
if (entryClass == null) {
return null;
}
T result = null;
try {
// 反射获取
Method method = entryClass.getDeclaredMethod(methodName);
method.setAccessible(true);
return (T) method.invoke(entryClass);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* @param entryClass
* @param methodName
* @param classArgs
* @param valueArgs
* @param <T>
* @return
*/
public static <T> T invokeForStatic(Class entryClass, String methodName, Class[] classArgs, Object[] valueArgs) {
if (entryClass == null) {
return null;
}
T result = null;
try {
Method method = entryClass.getDeclaredMethod(methodName, classArgs);
method.setAccessible(true);
return (T) method.invoke(entryClass, valueArgs);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* @param entryClass
* @param methodName
* @param initArgs
* @param <T>
* @return
*/
public static <T> T invokeForStatic(Class entryClass, String methodName, List<Object> initArgs) {
if (entryClass == null) {
return null;
}
T result = null;
try {
Class[] classArgs = new Class[initArgs.size()];
Object[] valueArgs = new Object[initArgs.size()];
for (int i = 0; i < initArgs.size(); i++) {
classArgs[i] = initArgs.get(i).getClass();
valueArgs[i] = initArgs.get(i);
}
Method method = entryClass.getDeclaredMethod(methodName, classArgs);
method.setAccessible(true);
return (T) method.invoke(entryClass, valueArgs);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* @param entryObject
* @param methodName
* @param <T>
* @return
*/
public static <T> T invokeForInstance(Object entryObject, String methodName) {
if (entryObject == null) {
return null;
}
T result = null;
try {
// 反射获取
Method method = entryObject.getClass().getDeclaredMethod(methodName);
method.setAccessible(true);
return (T) method.invoke(entryObject);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* @param entryObject
* @param methodName
* @param classArgs
* @param valueArgs
* @param <T>
* @return
*/
public static <T> T invokeForInstance(Object entryObject, String methodName, Class[] classArgs, Object[] valueArgs) {
if (entryObject == null) {
return null;
}
T result = null;
try {
Method method = entryObject.getClass().getDeclaredMethod(methodName, classArgs);
method.setAccessible(true);
return (T) method.invoke(entryObject, valueArgs);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* @param entryObject
* @param methodName
* @param initArgs
* @param <T>
* @return
*/
public static <T> T invokeForInstance(Object entryObject, String methodName, List<Object> initArgs) {
if (entryObject == null) {
return null;
}
T result = null;
try {
Class[] classArgs = new Class[initArgs.size()];
Object[] valueArgs = new Object[initArgs.size()];
for (int i = 0; i < initArgs.size(); i++) {
classArgs[i] = initArgs.get(i).getClass();
valueArgs[i] = initArgs.get(i);
}
Method method = entryObject.getClass().getDeclaredMethod(methodName, classArgs);
method.setAccessible(true);
return (T) method.invoke(entryObject, valueArgs);
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
//=============================================================================================//
// getter and setter
//=============================================================================================//
/**
* @param entryObject
* @param methodName
* @param <E>
* @return
*/
public static <E> E getInvoke(Object entryObject, String methodName) {
if (entryObject == null || StringUtils.isEmpty(methodName)) {
return null;
}
try {
Method method = entryObject.getClass().getDeclaredMethod(methodName);
method.setAccessible(true);
Object returnValue = method.invoke(entryObject);
return (E) returnValue;
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
/**
* @param entryObject
* @param fieldName
* @param <E>
* @return
*/
public static <E> E getInvokeByFieldName(Object entryObject, String fieldName) {
if (entryObject == null || StringUtils.isEmpty(fieldName)) {
return null;
}
try {
String methodName = "get" + StringUtils.capitalize(fieldName);
Method method = entryObject.getClass().getDeclaredMethod(methodName);
method.setAccessible(true);
Object returnValue = method.invoke(entryObject);
return (E) returnValue;
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
/**
* @param entryObject
* @param methodName
* @param <E>
* @return
*/
public static <E> E setInvoke(Object entryObject, String methodName, Object object) {
if (entryObject == null || StringUtils.isEmpty(methodName)) {
return null;
}
try {
Method method = entryObject.getClass().getDeclaredMethod(methodName, object.getClass());
method.setAccessible(true);
Object returnValue = method.invoke(entryObject, object);
return (E) returnValue;
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
/**
* @param entryObject
* @param fieldName
* @param <E>
* @return
*/
public static <E> E setInvokeByFieldName(Object entryObject, String fieldName, Object object) {
if (entryObject == null || StringUtils.isEmpty(fieldName)) {
return null;
}
try {
String methodName = "set" + StringUtils.capitalize(fieldName);
Method method = entryObject.getClass().getDeclaredMethod(methodName, object.getClass());
method.setAccessible(true);
Object returnValue = method.invoke(entryObject, object);
return (E) returnValue;
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
//=============================================================================================//
// the end
//=============================================================================================//
}
测试类:
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable, Cloneable {
private Integer id;
private String name;
private Date createTime;
/**
* 静态方法1
*/
public static void testCall1() {
System.out.println("testCall.1");
}
/**
* 静态方法2
* @param paramsMap
* @return
*/
public static Map<String, Object> testCall2(Map<String, Object> paramsMap) {
System.out.println("testCall.2," + paramsMap);
return paramsMap;
}
/**
* 静态方法
* @param paramsMap
* @return
*/
public static Map<String, Object> testCall3(HashMap<String, Object> paramsMap) {
System.out.println("testCall.3," + paramsMap);
return paramsMap;
}
/**
* 实例方法1
*/
public void testCall11() {
System.out.println("testCall.11");
}
/**
* 实例方法2
* @param paramsMap
* @return
*/
public Map<String, Object> testCall12(Map<String, Object> paramsMap) {
System.out.println("testCall.12," + paramsMap);
return paramsMap;
}
/**
* 实例方法3
* @param paramsMap
* @return
*/
public Map<String, Object> testCall13(HashMap<String, Object> paramsMap) {
System.out.println("testCall.13," + paramsMap);
return paramsMap;
}
}
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
public class ReflectCallMethodDemo {
public static void main(String[] args) {
// 静态方法调用=====1
Object result1 = ReflectCallMethod.invokeForStatic(User.class, "testCall1");
System.out.println("result1 is null ," + result1);
// 静态方法调用=====2
Map<String, Object> paramsMap1 = new HashMap<>();
paramsMap1.put("map", new Object());
Map<String, Object> result2 = ReflectCallMethod.invokeForStatic(User.class, "testCall2",
new Class[]{Map.class}, new Object[]{paramsMap1});
System.out.println("result2 is map ," + result2);
// 静态方法调用=====3
Map<String, Object> result3 = ReflectCallMethod.invokeForStatic(User.class, "testCall3", Arrays.asList(paramsMap1));
System.out.println("result3 is map ," + result3);
// 实例方法调用1
User user = new User();
Object result11 = ReflectCallMethod.invokeForInstance(user, "testCall11");
System.out.println("result11 is null ," + result11);
// 实例方法调用=====2
Map<String, Object> paramsMap21 = new HashMap<>();
paramsMap1.put("map", new Object());
Map<String, Object> result12 = ReflectCallMethod.invokeForInstance(user, "testCall12",
new Class[]{Map.class}, new Object[]{paramsMap21});
System.out.println("result12 is map ," + result2);
// 实例方法调用=====3
Map<String, Object> result13 = ReflectCallMethod.invokeForInstance(user, "testCall13", Arrays.asList(paramsMap21));
System.out.println("result13 is map ," + result13);
// setter and getter
User user2 = new User(2, "子贡", new Date());
String name = ReflectCallMethod.getInvoke(user2, "getName");
System.out.println("method name get ," + name);
String name2 = ReflectCallMethod.getInvokeByFieldName(user2, "name");
System.out.println("field name get ," + name2);
ReflectCallMethod.setInvoke(user2, "setName", "闵损");
ReflectCallMethod.setInvokeByFieldName(user2, "id", 200);
int id = ReflectCallMethod.getInvoke(user2, "getId");
System.out.println("method name get ," + id);
String name3 = ReflectCallMethod.getInvokeByFieldName(user2, "name");
System.out.println("field name get ," + name3);
}
}
猜你喜欢
- 2024-09-12 学习java应该如何理解反射?(怎么理解java反射)
- 2024-09-12 Java反射详解(java反射总结)
- 2024-09-12 读懂框架设计的灵魂—Java 反射机制
- 2024-09-12 Java的反射机制(java的反射机制是什么)
- 2024-09-12 java反射机制Java反射机制是什么?原理详解
- 2024-09-12 聊一聊Java当中的反射机制(java的反射机制是什么)
- 2024-09-12 Java反射机制的理解(java反射机制的理解和认识)
- 2024-09-12 聊一聊Java的反射机制?(java的反射机制是什么)
- 2024-09-12 Java学习之二——JAVA反射机制(java 反射机制原理)
- 2024-09-12 实操讲解Java的反射机制,你要是再看不懂,神仙都没救了
你 发表评论:
欢迎- 05-23Java线程池:核心参数与最佳实践
- 05-23深入理解 Java 的线程池原理
- 05-23面试突击34:如何使用线程池执行定时任务?
- 05-23Java线程池核心参数调优指南:掌控并发世界的钥匙
- 05-23Java线程池:优雅管理并发任务的艺术
- 05-23一篇文章快速搞懂Java中常用的四种线程池
- 05-23Java线程池工作原理深度解读:从创建到任务执行的全过程
- 05-23一文看懂:Java线程池任务拒绝机制解析
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)