浅谈Java泛型通配符解决了泛型的许多诟病(如不能重载)
泛型:
packageJava基础增强;
importjava.util.ArrayList;
importjava.util.List;
importorg.junit.Test;
publicclassTest2{
@Test
publicvoidfun1(){
Object[]objects=newObject[10];
Listlist=newArrayList();
String[]strings=newString[10];
List<String>list2=newArrayList<String>();
Object[]objects2=newString[10];
//下面这句编译不报错,但是运行包存储异常错误
objects2[0]=newInteger(100);//java.lang.ArrayStoreException:java.lang.Integer
//下面这句编译报错
// List<Object>objects3=newArrayList<String>();
/*
*泛型引用和创建两端,给出的泛型变量必须一致
*虚拟机根本就不检查泛型存不存在
*/
}
publicvoidfun2(){
List<Integer>list=newArrayList<Integer>();
this.print1(list);//1.print1方法只能是存储Integer不能使Object
//==========================
List<Integer>list2=newArrayList<Integer>();
print(list2);
List<String>list3=newArrayList<String>();
print(list3);
}
//2.泛型的方法不能重载,因为泛型擦出后是一样的方法,也就是如果一个方法里的形参的泛
//型的,则不能重载这个方法,即:即使方法名相同,参数不同也不行,但是普通方法可以重载(同名不同参)
publicvoidprint1(List<Integer>objects){
}
publicvoidprint2(List<String>strings){
}
//但是后来聪明的程序员使用通配符解决了这个泛型不能重载的问题
publicvoidprint(List<?extendsObject>list){
}
//但是下面两个普通方法可以重载
publicvoida(Strings){
}
publicvoida(inti){
}
}
泛型的方法不能重载,因为泛型擦出后是一样的方法,也就是如果一个方法里的形参的泛型的,则不能重载这个方法,即:即使方法名相同,参数不同也不行,但是普通方法可以重载(同名不同参)
那个HTML本来打算过渡到XML的,且中间有个XHTML,但是迁移了10年还没过渡成功,结果HTML升级了,为HTML5,最终宣告迁移失败,还是用HTML吧。
其实在JDK1.5以后加入泛型,虽然可以在编译器检查,但是也引入了许多诟病的,其实在编译后,已经擦出了泛型,也就是说Java虚拟机不认识泛型的。
以上就是小编为大家带来的浅谈Java泛型通配符解决了泛型的许多诟病(如不能重载)的全部内容了,希望对大家有所帮助,多多支持毛票票~