黑马程序员技术交流社区

标题: 关于泛型 [打印本页]

作者: xkfxm    时间: 2013-8-6 10:37
标题: 关于泛型
本帖最后由 xkfxm 于 2013-8-6 19:30 编辑

            ArrayList arr = new ArrayList<Integer>();
             arr.add("asd");  
为什么可以放S听类型的对象?他不是指向ArrayList<Integer>()?
这里对象加入泛型只能放Integer,但是运行时也没错误,代表String也放进去了。这跟没加泛型有什么区别|??

             ArrayList<Integer> arr1 = new ArrayList();
arr1只能存放Integer及其子类对象,上面的代码和ArrayList<Integer> arr1 = new ArrayList<Integer>();有什么区别?

作者: 草帽    时间: 2013-8-6 11:01
jdk1.5出现的泛型,为了兼容低版本的jdk象楼主那样的是可以写的。
第一个错误是因为在编译之后那些类型参数的信息就去掉了所以是可以添加的(这里add是运行时)。具体讲解可以参阅张孝祥老师的高新技术上的讲解。
第二个错误应该在编译时就会出错,因为arr1只能存放Integer类型的
以上个人见解,共同学习
作者: 薛淑凯    时间: 2013-8-6 11:02
可以把他们当成多态来想就明白了
作者: 李政    时间: 2013-8-6 11:06
本帖最后由 李政 于 2013-8-6 11:09 编辑

课中有讲到
参数化类型与原始类型的兼容性:
参数化类型可以引用一个原始类型的对象,编译报告警告,例如, Collection<String> c = new Vector();//可不可以,不就是编译器一句话的事吗?
原始类型可以引用一个参数化类型的对象,编译报告警告,例如, Collection c = new Vector<String>();//原来的方法接受一个集合参数,新的类型也要能传进去

小总结
  1. import java.util.*;
  2. class Demo
  3. {
  4.         public static void main(String[] args)
  5.         {        
  6.                 Collection<String> c = new Vector();//编译时出警告

  7.                 //c.add(5);//编译失败
  8.                
  9.                 c.add("5");//对于c 只能存String类型的 但可以指向一个原始类型对象

  10.                 Collection c1= new Vector<String>();//编译时也出警告

  11.                 c1.add(5);//对于c1 对象中声明的String类型表示这个对象可以接收String类型的,同时也可以接收其他类型的
  12.                 //System.out.println(c1);

  13.                 //总结,能接收什么类型的对象,看左边,就是看这个对象的类型上面有没有参数化
  14.         }
  15. }
复制代码





作者: xkfxm    时间: 2013-8-6 13:31
草帽 发表于 2013-8-6 11:01
jdk1.5出现的泛型,为了兼容低版本的jdk象楼主那样的是可以写的。
第一个错误是因为在编译之后那些类型参数 ...

噢噢,这个很到位,我忘了编译后会去掉类型参数信息。。谢谢,学习了
作者: xkfxm    时间: 2013-8-6 18:54
草帽 发表于 2013-8-6 11:01
jdk1.5出现的泛型,为了兼容低版本的jdk象楼主那样的是可以写的。
第一个错误是因为在编译之后那些类型参数 ...

恩恩,学习了,没想到add方法和类型参数不是一个时期




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2