Java泛型(5):擦除与补偿】的更多相关文章

最近看了<thinking in java>的第十五章泛型,感觉有些东西需要记录下来. 泛型是Java SE5才被引入的概念,现在我的工作中泛型主要使用在集合,这样可以知道set()和get()的类型(类型检查是在编译阶段,可以使用反射绕过编译),而不必再进行额外的转型操作. 今天,我们主要是来聊一聊Java泛型的擦除. 或许,你对Java泛型的擦除的概念不是很理解,下面我们来看一个例子: 很多人会认为ArrayList<String>和ArrayList<Integer&g…
详细内容:参考java编程思想P373,p650. Java 泛型(Generic)的引入加强了参数类型的安全性,减少了类型的转换,但有一点需要注意:Java 的泛型在编译器有效,在运行期被删除,也就是说所有泛型参数类型在编译后都会被清除掉: public class ErasedType{ Class c1 = List<String>().getClass(); Class c2 = List<Integer>().getClass(); System.out.print(c1…
头次写博客,想说的东西不难,关于泛型的疑问,是前一阵在学习jackson中遇到的. 下面就把我所想到的.遇到的,分享出来. 泛型是JDK1.5后的一个特性,是一个参数类型的应用,可以将这个参数声明在类.接口.方法中,就像我们方法中定义的局部变量一样:在工作中,我们常在List,Map,Set等集合对象中使用,或者我们自己声明的类中使用. 说到泛型,就不得说起“擦除”这个概念,相比于c#来说,java的泛型只存在于程序的源码中,在编译后的class文件中不存在,这个过程就是--泛型"擦除"…
一.泛型的引入原因 在操作集合的时候,之前方法的定义都是Object类型,向集合中添加对象,都自动向上转型,加入的元素可以是任何类型 但是,在取出元素的时候,通常想要使用对象的特有功能,就必须向下转型,此时就可能出现类型转换异常,存在安全隐患. 在JDK1.5时候提出一个解决方案:泛型. 二.泛型的定义及好处 泛型:是一种应用在编译时期的安全机制,具体的做法:有点类似于数组的思想,定义操作的时候,指定好要操作的类型信息 eg:ArrayList<String>:表示该ArrayList只能操作…
目录   1.导读  2.为何需要泛型?   3.泛型的定义格式   3.泛型的好处  4.什么时候使用泛型?   5.泛型的擦除   6.泛型的补偿  7.泛型的应用      7.1[泛型类]     7.2[泛型方法]     7.3[泛型接口]  8.泛型の通配符:?  9.泛型的限定 1.导读 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数.Generic有“类的,属性的”之意,在Java中代表泛型.泛型作为一种安全机制而产生.…
一.函数参数与泛型比较 泛型(generics),从字面的意思理解就是泛化的类型,即参数化类型.泛型的作用是什么,这里与函数参数做一个比较: 无参数的函数: public int[] newIntArray(){ return new int[6]; } 函数功能即返回一个大小为6的数组,但是这个函数只能返回固定大小为6的数组,如果想返回不同size的数组则还要重新编写函数.解决方法就是使用函数参数,传入一个代表数组大小的size. 有参数的函数:我们在写一个函数时,往往需要向函数传入一些参数,…
import sun.net.www.content.text.Generic; import java.lang.reflect.Array; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class Test { public static void main(String[] args) { // ClassTypeCapture.test(); // Instantia…
先看一个例子: Class<?> c1 = new ArrayList<String>().getClass(); Class<?> c2 = new ArrayList<Integer>().getClass(); System.out.println(c1 == c2); // true 虽然泛型类的参数不同,但是结果却是TRUE.这是因为在泛型代码内部,无法获得任何有关泛型参数类型的信息. Java泛型是通过擦除来实现的.这意味着当你在使用泛型时,任何…
一.万恶的擦除 我在自己总结的[Java心得总结三]Java泛型上——初识泛型这篇博文中提到了Java中对泛型擦除的问题,考虑下面代码: import java.util.*; public class ErasedTypeEquivalence { public static void main(String[] args) { Class c1 = new ArrayList<String>().getClass(); Class c2 = new ArrayList<Integer…
类型擦除 代码片段一 Class c1 = new ArrayList<Integer>().getClass(); Class c2 = new ArrayList<String>().getClass(); System.out.println(c1 == c2); /* Output true */ 显然在平时使用中,ArrayList<Integer>()和new ArrayList<String>()是完全不同的类型,但是在这里,程序却的的确确会输…