reflect 反射结合集合泛型的总结

集合泛型:

可以放任何对象的 ArrayList  ArrayList list = new ArrayList();  没有限定泛型类型.

list.add("lilin");list.add(100);System.out.println(list);//很容得知结果能够是["lilin",100];

ArrayList<String> list1 = new ArrayList<String>(); 限定了只能存放String类型的数据

list1.add("lilin");
// String 泛型的集合 是不能添加int的类型的数据的
// list1.add(100);//此时编译是不会通过的,泛型检查了输入的正确性:

泛型的检查,只会在编译的时候检查,如果我们能够绕过编译的动作,就能避开输入的正确的检查操作,导致String泛型的集合中会存在不是String类型的数据.

反射reflect的操作,无论是CLass Method Filed 等,都是运行时加载的,不需要通过编译操作.

//下面通过反射操作,实现把int 100  放入  String泛型的list中去:

ArrayList<String> list = new ArrayList<String>();
Class c = list.getClass();
 try {       //通过反射,获取到list的add方法,简单处理异常信息
            Method m = c2.getMethod("add", Object.class);       //通过方法的反射,就能把int类型的数据,添加到string泛型的list中去
         m.invoke(list1, 100);        //结果很明显,100 能够成功的添加进去
            System.out.println(list1);        //此时要特别注意的:不能在用String 类型来for循环当前的list; 在循环到int的100会跑出类型不匹配的异常信息
            for (String s : list1) {
                System.out.println(s);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

其实:本质的原因是,泛型主要是控制输入的正确验证的,而编译后的泛型集合类型,也就是  Class c1 = list.getClass();  Class c2 = list1.getClass();

在编译后,集合的泛型是去泛型的,通过验证System.out.println(c1 == c2);   结果是true,也就是集合编译后,都是同一个类类型.

所以:集合的泛型和反射的相关的方法结合使用时,要特别注意,反射的是运行时加载的,集合的编译检查输入的正确是会被绕过的.

时间: 2024-11-06 02:22:49

reflect 反射结合集合泛型的总结的相关文章

通过反射了解集合泛型的本质

通过反射了解集合泛型的本质 import java.lang.reflect.Method; import java.util.ArrayList; /** * 通过反射了解集合泛型的本质 * @author shm * */ public class MethodDemo02 { public static void main(String[] args) { ArrayList list = new ArrayList(); list.add("hello"); list.add(

Java反射的理解(六)-- 通过反射了解集合泛型的本质

Java反射的理解(六)-- 通过反射了解集合泛型的本质 上述写了那么多,我们可能会有个疑问,为什么要用反射,步骤比我们常规的加载类操作复杂多了,别急,这个问题我最后才解答,我们先来了解集合泛型的本质. 直接上代码: import java.lang.reflect.Method; import java.util.ArrayList; public class MethodDemo4 { public static void main(String[] args) { ArrayList li

Java--Reflect(反射)专题6——通过反射了解集合泛型的本质

转载请注明:http://blog.csdn.net/uniquewonderq 通过Class,Method来认识泛型的本质 反射的操作都是编译之后的操作,即运行时刻进行操作 c1==c2结果返回true,说明编译之后,集合的泛型是去泛型化的 就是说编译之后这个集合没有泛型了. java中集合的泛型是防止错误输入的,只在编译阶段有效, 过了编译就无效了. 验证:我们可以通过方法的反射来操作,绕过编译 package com.test; import java.lang.reflect.Meth

java通过反射了解集合泛型的本质

Java —— Reflect反射机制

Class类的使用 OOP的世界里,万事万物皆对象.类是谁的对象呢?——类是对象,类是java.lang.Class类的实例对象!There is a class named class. 实例: //有一个类 class Foo { void print() {System.out.println("Foo");} } //在main函数里: public static void main(String[] args) { //Foo这个类也是一个实例对象,Class类的实例对象,如

java 泛型深入之Set有用工具 各种集合泛型深入使用演示样例,匿名内部类、内部类应用于泛型探讨

//Sets.java package org.rui.generics.set; import java.util.HashSet; import java.util.Set; /** * 一个Set有用工具 * @author lenovo * */ public class Sets { public static<T> Set<T> union(Set<T> a,Set<T> b) { Set<T> result=new HashSet&

(翻译)反射处理java泛型

当我们声明了一个泛型的接口或类,或需要一个子类继承至这个泛型类,而我们又希望利用反射获取这些泛型参数信息.这就是本文将要介绍的ReflectionUtil就是为了解决这类问题的辅助工具类,为java.lang.reflect标准库的工具类.它提供了便捷的访问泛型对象类型(java.reflect.Type)的反射方法. 本文假设你已经了解java反射知识,并能熟练的应用.如果还不了解java反射知识,那么你可以先移步到Oracel反射课程,这可能是你开始学习反射的好起点. ReflectionU

java 反射和泛型-反射来获取泛型信息

通过指定对应的Class对象,程序可以获得该类里面所有的Field,不管该Field使用private 方法public.获得Field对象后都可以使用getType()来获取其类型. Class<?> type = f.getType();//获得字段的类型 但此方法只对普通Field有效,若该Field有泛型修饰,则不能准确得到该Field的泛型参数,如Map<String,Integer>; 为了获得指定Field的泛型类型,我们采用: Type gType = f.getG

【DAY12】第十二天集合&泛型&IO学习笔记

hash:散列 ------------------ Hashset集合内部是通过HashMap进行实现的.使用的是HashMap中key部分. 对象在添加进集合中时,首选会对hashcode进行处理(hashcode右移16位和 自身做异或运算)得到一个经过处理的hash值,然后该值和集合的容量进行 &运算,得到介于0和集合容量值之间一个数字.该数字表示着数组的下标. 也就是该元素应该存放在哪个元素中. Map与Collection -------------- Map与Collection在