使用传统集合的问题分析
- 不能对加入到集合 ArrayList 中的数据类型进行约束(不安全)遍历的时候,需要进行类型转换,如果集合中的数据量较大,对效率有影响
泛型的好处
- 编译时,检查添加元素的类型,提高了安全性减少了类型转换的次数,提高效率
35.2 泛型介绍不使用泛型
Dog -> 加入 -> Object -> 取出 -> Dog // 放入到 ArrayList 会先转成 Object,在取出时,还需要转换成 Dog使用泛型
Dog -> Dog -> Dog //放入时,和取出时,不需要类型转换,提高效率
- 泛型又称参数化类型,泛(广泛)型(类型)=> Integer、String、Dog,是JDK5.0 出现的新特性,解决数据类型的安全性问题在类声明或实例化时只要指定好需要的具体类型即可Java 泛型可以保证如果程序在编译时没有发出警告,运行时就不会产生 ClassCastException 异常,同时,代码更加简洁、健壮泛型的作用是:可以在类声明时通过一个标识表示类中某个属性的类型,或者是某个方法的返回值的类型,或者是参数类型
interface 接口
class 类
泛型的实例化说明:
其中,T,K,V不代表值,而是表示类型任意字母都可以,常用 T 表示,是Type缩写
要在类名后面指定类型参数的值(类型),如:
- List
//E具体的数据类型在定义Person对象的时候指定,即在编译期间,就确定E是什么类型 Personp = new Person ("发疯的小猫咪"); System.out.println(p.toString());
class Person泛型的使用形式{ E e; Person(E e){ this.e = e; } @Override public String toString() { return "Person{" + "e=" + e + '}' + e.getClass(); } }
ArrayList
List
在实际开发中,往往简写成
ArrayList
List
interface List{} public class HashSet {}..
- T,E 只能是 引用类型
看看下面语句是否正确?
Listlist = new ArrayList ();//ok List list2 = new ArrayList ();//错误
- 在给泛型指定具体类型后,可以传入该类型或者其子类类型
class A {}
class B extends A {}
class Pig {}
...
Pig pig1 = new Pig<>(new A());
Pig pig2 = new Pig<>(new B());
- 泛型使用形式
List
List
基本语法 基本语法 基本语法 例子: 2.>:支持任意泛型类型 例子:
class 类名普通成员可以使用泛型(属性、方法)使用泛型的数组,不能初始化静态方法中不能使用类的泛型(泛型类的类型,是在创建对象时确定的,因为创建对象时,需要指定确定类型)如果在创建对象时,没有指定类型,默认为 Object
35.6 自定义泛型接口
interface 接口名接口中,静态成员也不能使用泛型泛型接口的类型,在继承接口或者实现接口时确定没有指定类型,默认为 Object
35.7 自定义泛型方法
修饰符 泛型方法,可以定义在普通类中,也可以定义在泛型类中可以使用类声明的泛型,也可以使用自己声明的泛型当泛型方法被调用时,类型会确定public void eat(E e) {},修饰符后没有
方法不是泛型方法,而是使用了泛型class Car {
public void run() {}
//
35.8 泛型的继承和通配符
泛型不具备继承性
List
2. extends A>:支持A类以及A类的子类,规定了泛型的上限
3. super A>:支持A类以及A类的父类,不限于直接父类,规定了泛型的下限public static void printCollection1(List> c) {}
public static void printCollection2(List extends AA> c) {}
public static void printCollection3(List super AA> c) {}



