课程名称:通过反射了解泛型本质
课程章节:第六章
主讲老师:Cedar
课程内容:
//泛型 public class ClassDemo4 { public static void main(String[] args) { List<String> list1 = new ArrayList<String>(); list1.add("hello"); Class c1 = list1.getClass(); Class c2 = list1.getClass(); //验证可知:二者的类类型是一样的 System.out.println(c1 == c2); /** * c1 == c2结果返回true,说明编译之后集合的泛型是去泛型化的 * java中集合的泛型,是防止错误输入的,只在编译阶段有效 * 绕过编译就无效了 * 验证:我们通过反射绕过编译 */ try { Method m = c2.getMethod("add", Object.class); m.invoke(list1, 20); System.out.println(list1.size()); System.out.println(list1); //现在不能for循环,会有类型转换错误 } catch (NoSuchMethodException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (InvocationTargetException e) { e.printStackTrace(); } } }
课程收获:
这节课其实还学习到一个非常重要的地方就是:静态代码是在编译时找出错误,比如你在List中指定泛型String的话,如果你后面匹配的不是String,比如说是Object或者说是Int,那么代码编译就会出问题,当然闲杂摘掉了,这个问题,可以通过反射来避过,但是如果通过for循环的,List就会出问题。
比如说多态的话,编译时是静态绑定,那么它绑定的就是父类的方法,当运行时,就动态绑定到了子类方法上,没学这门课的时候,对多态其实一直都懵懵懂懂的,学了这门课以后,这些内容又有了深的理解。
总的来说,这门课还是非常不错的,适合反复听,跟着一起练习,一定可以学到新的东西!
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦