反射与泛型的实际应用
前置知识
1.反射的作用-绕过编译阶段为集合添加数据
2.泛型只是在编译阶段可以约束集合只能操作某种数据类型,在编译成Class文件进入运行阶段的时候其真实类型都是ArrayList了,泛型相当于被擦除了。
反射的作用
理解泛型擦除
反射是作用在运行时的技术,运行时已经不存在泛型了。
import java.util.ArrayList;
public class ReflectDemo {
public static void main(String[] args) {
// 需求:反射实现泛型擦除后,加入其他类型的元素
ArrayList<String> list1 = new ArrayList<>();
ArrayList<Integer> list2 = new ArrayList<>();
System.out.println(list1.getClass());
System.out.println(list2.getClass());
//观察这里的类对象是否相同
System.out.println(list1.getClass() == list2.getClass()); //ArrayList.class
}
}
运行结果
用反射就添加不属于泛型的数据
1.使用反射技术获取方法并使用
使用反射技术获取方法并使用
import java.lang.reflect.Method;
import java.util.ArrayList;
public class ReflectDemo {
public static void main(String[] args) throws Exception{
ArrayList<Integer> list = new ArrayList<>();
list.add(66);
list.add(88);
//list.add("肥皂"); 这样肯定不被允许
Class c = list.getClass(); //ArrayList.class --> public boolean add(E e)
//定义c类中的add方法
Method add = c.getDeclaredMethod("add",Object.class);
boolean rs = (boolean) add.invoke(list,"肥皂");
System.out.println(list);
}
}
运行结果
2.使用不受约束的对象去操控受约束的对象
list2和list指向同一个地址,然后list2不受约束
import java.util.ArrayList;
public class ReflectDemo {
public static void main(String[] args) throws Exception{
ArrayList<Integer> list = new ArrayList<>();
list.add(66);
list.add(88);
//list.add("肥皂"); 这样肯定不被允许
//list2和list指向同一个地址,然后list2不受约束
ArrayList list2 = list;
list2.add("幽灵");
list2.add("Locus");
System.out.println(list);
}
}
运行结果
绕过编译阶段,制作企业级通用框架
案例
需求:给出任意一个对象,在不清楚对象字段的情况下,可以把对象的字段名称和对应值存储到文件中去
首先写一个老师学生类