时间:2021-05-19
泛型:
package Java基础增强;import java.util.ArrayList;import java.util.List;import org.junit.Test;public class Test2 { @Test public void fun1(){ Object[] objects = new Object[10]; List list = new ArrayList(); String[] strings = new String[10]; List<String> list2 = new ArrayList<String>(); Object[] objects2 = new String[10]; //下面这句编译不报错,但是运行包存储异常错误 objects2[0]=new Integer(100);//java.lang.ArrayStoreException: java.lang.Integer //下面这句编译报错// List<Object> objects3 = new ArrayList<String>(); /* * 泛型引用和创建两端,给出的泛型变量必须一致 * 虚拟机根本就不检查泛型存不存在 */ } public void fun2(){ List<Integer> list = new ArrayList<Integer>(); this.print1(list);//1.print1方法只能是存储Integer不能使Object //========================== List<Integer> list2 = new ArrayList<Integer>(); print(list2); List<String> list3 = new ArrayList<String>(); print(list3); } //2.泛型的方法不能重载,因为泛型擦出后是一样的方法,也就是如果一个方法里的形参的泛 //型的,则不能重载这个方法,即:即使方法名相同,参数不同也不行,但是普通方法可以重载(同名不同参) public void print1(List<Integer> objects){ } public void print2(List<String> strings){ } //但是后来聪明的程序员使用通配符解决了这个泛型不能重载的问题 public void print(List<? extends Object> list){ } //但是下面两个普通方法可以重载 public void a(String s){ } public void a(int i){ }}泛型的方法不能重载,因为泛型擦出后是一样的方法,也就是如果一个方法里的形参的泛型的,则不能重载这个方法,即:即使方法名相同,参数不同也不行,但是普通方法可以重载(同名不同参)
那个HTML本来打算过渡到XML的,且中间有个XHTML,但是迁移了10年还没过渡成功,结果HTML升级了,为HTML5,最终宣告迁移失败,还是用HTML吧。
其实在JDK1.5以后加入泛型,虽然可以在编译器检查,但是也引入了许多诟病的,其实在编译后,已经擦出了泛型,也就是说Java虚拟机不认识泛型的。
以上就是小编为大家带来的浅谈Java泛型通配符解决了泛型的许多诟病(如不能重载)的全部内容了,希望对大家有所帮助,多多支持~
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
简介前两篇文章介绍了泛型的基本用法、类型擦除以及泛型数组。在泛型的使用中,还有个重要的东西叫通配符,本文介绍通配符的使用。这个系列的另外两篇文章:Java泛型总
c#的泛型没有类型通配符,原因是.net的泛型是CLR支持的泛型,而Java的JVM并不支持泛型,只是语法糖,在编译器编译的时候都转换成object类型类型通配
本文实例讲述了Java泛型的使用限制。分享给大家供大家参考,具体如下:一什么情况下不能使用泛型1不能使用泛型的形参创建对象。To=newT();//不允许2在泛
本文实例讲述了Java中泛型通配符的使用方法。分享给大家供大家参考,具体如下:一点睛引入通配符可以在泛型实例化时更加灵活地控制,也可以在方法中控制方法的参数。语
本文实例讲述了Java泛型类与泛型方法的定义。分享给大家供大家参考,具体如下:Java泛型类的定义一点睛泛型类定义的语法如下:[访问修饰符]class类名称泛型