版权声明:关注微信公众号:摸鱼科技资讯,联系我们 https://blog.csdn.net/qq_36949176/article/details/87903142
泛型:
jdk1.5出现的安全机制。
好处:
1,将运行时期的问题ClassCastException转到了编译时期。
2,避免了强制转换的麻烦。
<>:什么时候用?当操作的引用数据类型不确定的时候。就使用<>。将要操作的引用数据类型传入即可.
其实<>就是一个用于接收具体引用数据类型的参数范围。
在程序中,只要用到了带有<>的类或者接口,就要明确传入的具体引用数据类型 。
泛型技术是给编译器使用的技术,用于编译时期。确保了类型的安全。
运行时,会将泛型去掉,生成的class文件中是不带泛型的,这个称为泛型的擦除。
为什么擦除呢?因为为了兼容运行的类加载器。
泛型的补偿:在运行时,通过获取元素的类型进行转换动作。不用使用者在强制转换了。
泛型的通配符:? 未知类型。
泛型的限定:
? extends E: 接收E类型或者E的子类型对象。上限
一般存储对象的时候用。比如 添加元素 addAll.
? super E: 接收E类型或者E的父类型对象。 下限。
一般取出对象的时候用。比如比较器。
自定义泛型类:
泛型类:
package change.bean;
public class Tool<Q> {
private Q q;
public Q getObject() {
return q;
}
public void setObject(Q object) {
this.q = object;
}
}
Test类
package change;
import change.bean.Person;
import change.bean.Tool;
public class fanxin {
public static void main(String[] args) {
// TODO Auto-generated method stub
Tool<Person> t=new Tool<Person>();
t.setObject(new Person());
Person p=t.getObject();
}
}
泛型定义在方法上
public <w> void show(w str){
System.out.println("show:"+str.toString());
}
当方法静态时,不能访问类上定义的泛型,如果静态方法使用泛型
只能将泛型定义在方法上
/*
* 当方法静态时,不能访问类上定义的泛型,如果静态方法使用泛型
* 只能讲泛型定义在方法上
*/
public static <Y> void Method(Y obj){
System.out.println("method:"+obj);
}