1、jdk5.0新增特性
2、在集合中使用泛型
①集合接口或集合类在jdk5.0时都修改为带泛型的结构
②实例化集合时,可以指明具体的泛型类型
③指明完以后,在集合类或接口中凡是定义类或接口时,内部结构(属性、方法、构造器等)使用到类的泛型位置,都指定为实例化的泛型类型
④注意点:泛型的类型必须是类,不能是基本数据类型,用到基本数据类型得对方用其包装类
⑤实例化时,没有指明泛型类型。默认类型为java.lang.Object类型
⑥写法:
【注意】
①如果定义了泛型类型,但是实例化时没有指明泛型类型,则认为泛型类型为Object
要求:若定义的类中带泛型,建议实例化时指明泛型类型
②如果子类在继承父类时,指明了泛型类,则实例化子类对象时,不再需要指明泛型类型
没有指明泛型类型的,再累仍然是泛型类
③泛型不同的引用不能相互赋值
④静态方法中不能使用类的泛型
因为泛型的指定是在创建这个类的对象后,而静态结构是早于创建对象的,此时泛型还没有指定
⑤异常类不能声明为为泛型类
catch括号中的意思是,如果是个异常类,应该怎么处理,所以catch中也不能用泛型
⑥
⑦在声明构造器时,不要加泛型,但在实例化时需要加
声明构造器时
实例化时
⑧jdk7中出现泛型的简化处理,就是new后面的尖括号可以不加东西
1、泛型方法:在方法中出现了泛型结构,泛型参数与类的泛型参数没有任何关系。换句话说,就是,泛型方法和其所属的类是不是泛型类无关
方法的泛型类型在调用时指明
定义的泛型方法:
意思就是:泛型方法定义在order类中,但是方法的返回值类型是跟传入的参数arr有关,而跟所在的order的类型无关
2、泛型方法是可以定义为静态的,原因是因为方法的泛型类型是在声明方法的参数时确定,而不是实例化时确定
1、类A和类B是子父类关系,但是G<<>>和G<<>>不具有子父类关系,而是并列关系
【补充】类A是类B的父类,则A<<
类A和类B是子父类关系,但是G<<>>和G<<>>不具有子父类关系,而他们的通用父类是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