目录
泛型的理解和好处
使用传统方法的问题分析
使用泛型
泛型介绍
泛型的语法
泛型的声明
泛型的注意事项和细节
自定义泛型类
编辑
自定义泛型接口
自定义泛型方法
泛型的继承和通配符
泛型的理解和好处
看一个需求
1)请编写程序,在ArrayList 中,添加3个Dog对象
2) Dog对象含有name 和 age,并输出name 和 age (要求使用getXxx())
先使用传统的方法来解决 ->引出泛型
// 传统方式实现
// 但是有一个问题, 如果程序员不小心加了一直猫进去, 那么就可能发生向下转型异常, 这一个隐患, 但是编译器发现不了的
使用传统方法的问题分析
1)不能对加入到集合ArrayList中的数据类型进行约束(不安全)
2)遍历的时候,需要进行类型转换,如果集合中的数据量较大,对效率有影响
使用泛型
可以看到加入泛型后, 再添加猫就报错了
同时在遍历的时候, 可以直接取出Dog类型而不是Object类 , 省去了向下转型, 提高了效率
泛型介绍
泛(广泛)型(类型)=> Integer, String, Dog
1)泛型又称参数化类型,是Jdk5.0 出现的新特性,解决数据类型的安全性问题
2)在类声明或实例化时只要指定好需要的具体的类型即可
3)Java泛型可以保证如果程序在编译时没有发出警告,运行时就不会产生 ClassCastException异常。同时,代码更加简洁、健壮
4)泛型的作用是:可以在类声明时通过一个标识表示类中某个属性的类型,或者是某个方法的返回值的类型,或者是参数类型。
泛型的语法
泛型的声明
interface 接口<T>{} 和 class类<K,V>{}
1)其中,T,K,V不代表值,而是表示类型。
2)任意字母都可以。常用T表示,是Type的缩写
○泛型的实例化: 要在类名后面指定类型参数的值(类型)。
如:
1) List<String> strList = new ArrayList<String>();[举例说明]
2) lterator<Customer> iterator = customers.iterator();
泛型的注意事项和细节
1. 给泛型指定的数据类型是, 要求是引用类型, 而不是基本数据类型
2. 给泛型指定具体类型后, 可以传入该类型或者其子类类型
3. 泛型的使用形式, 在实际开发中, 往往简写, 省略后面尖括号的泛型
4. 不指定泛型时, 默认是Object类型
自定义泛型类
注意细节
1)普通成员可以使用泛型(属性、方法)
2) 使用泛型的数组,不能初始化, 因为数组在new 不能确定T的类型,就无法在内存开空间
3)静态方法中不能使用类的泛型, 因为静态是和类相关的,在类加载时,对象还没有创建 , 所以,如果静态方法和静态属性使用了泛型,JVM就无法完成初始化
4)泛型类的类型,是在创建对象时确定的(因为创建对象时,需要指定确定类型)
5) 如果在创建对象时,没有指定类型,默认为Object
自定义泛型接口
注意细节
1) 接口中,静态成员也不能使用泛型(这个和泛型类规定一样)
2) 泛型接口的类型, 在继承接口或者实现接口时确定
3) 没有指定类型,默认为Object
自定义泛型方法
注意细节
1.泛型方法,可以定义在普通类中, 也可以定义在泛型类中
2.当泛型方法被调用时,类型会确定
3. public void eat(E e){},修饰符后没有<T,R..> eat 方法不是泛型方法,而是使用了泛型
自定义泛型方法练习题
--实例
泛型的继承和通配符
1)泛型不具备继承性
List<Object> list = new ArrayList<String>();//对吗?
2)<?>: 支持任意泛型类型
3)<? extends A>: 支持A类以及A类的子类,规定了泛型的上限
4) <? super A>: 支持A类以及A类的父类,不限于直接父类,规定了泛型的下限
--实例
编写了三个类
<?>: 支持任意泛型类型
<? extends A>: 支持A类以及A类的子类,规定了泛型的上限
<? super A>: 支持A类以及A类的父类,不限于直接父类,规定了泛型的下限