这里写目录标题
- 一、泛型的使用
- 自定义泛型类
- 泛型方法说明
- 泛型在继承方面的体现
- 通配符的使用
- 有限制条件的通配符的的使用
- 每日一考
一、泛型的使用
1、jdk5.0新增特性
2、在集合中使用泛型
①集合接口或集合类在jdk5.0时都修改为带泛型的结构
②实例化集合时,可以指明具体的泛型类型
③指明完以后,在集合类或接口中凡是定义类或接口时,内部结构(属性、方法、构造器等)使用到类的泛型位置,都指定为实例化的泛型类型
④注意点:泛型的类型必须是类,不能是基本数据类型,用到基本数据类型得对方用其包装类
⑤实例化时,没有指明泛型类型。默认类型为java.lang.Object类型
⑥写法:
自定义泛型类
【注意】
①如果定义了泛型类型,但是实例化时没有指明泛型类型,则认为泛型类型为Object
要求:若定义的类中带泛型,建议实例化时指明泛型类型
②如果子类在继承父类时,指明了泛型类,则实例化子类对象时,不再需要指明泛型类型
没有指明泛型类型的,再累仍然是泛型类
③泛型不同的引用不能相互赋值
④静态方法中不能使用类的泛型
因为泛型的指定是在创建这个类的对象后,而静态结构是早于创建对象的,此时泛型还没有指定
⑤异常类不能声明为为泛型类
catch括号中的意思是,如果是个异常类,应该怎么处理,所以catch中也不能用泛型
⑥
⑦在声明构造器时,不要加泛型,但在实例化时需要加
声明构造器时
实例化时
⑧jdk7中出现泛型的简化处理,就是new后面的尖括号可以不加东西
泛型方法说明
1、泛型方法:在方法中出现了泛型结构,泛型参数与类的泛型参数没有任何关系。换句话说,就是,泛型方法和其所属的类是不是泛型类无关
方法的泛型类型在调用时指明
定义的泛型方法:
意思就是:泛型方法定义在order类中,但是方法的返回值类型是跟传入的参数arr有关,而跟所在的order的类型无关
2、泛型方法是可以定义为静态的,原因是因为方法的泛型类型是在声明方法的参数时确定,而不是实例化时确定
泛型在继承方面的体现
1、类A和类B是子父类关系,但是G
<
<
<A
>
>
>和G
<
<
<B
>
>
>不具有子父类关系,而是并列关系
【补充】类A是类B的父类,则A
<
<
<G
>
>
>和B
<
<
<G
>
>
>具有子父类关系
通配符的使用
类A和类B是子父类关系,但是G < < <A > > >和G < < <B > > >不具有子父类关系,而他们的通用父类是G < < <? > > >
2、对于List
<
<
<?
>
>
>就不能向其内部添加数据了,除了添加null之外
允许读取数据,读取数据的类型为Object
有限制条件的通配符的的使用
G
<
<
<? extends A
>
>
> list:的意思就是对于其对象list,可以将A或A的子类的对象赋给list,范围是(-∞,A ]
G
<
<
<? super A
>
>
> list:范围是[ A,+∞)
但是赋值后,如果想要读取数据,是要根据被赋值的变量的范围确定接收到的读取数据的值的类型。比如将list3赋给list1,list1的类型是小于等于Person,他可能就是Person类,要是写其子类student就会出错,所以接收的数据是Person;将list4赋给list2,而list2的范围是大于等于Person,还可能是Person的父类,所以接收的数据是Object