A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© danerchen 初级黑马   /  2014-4-23 23:30  /  740 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  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>();有什么区别?

2 个回复

正序浏览
本帖最后由 igi9009 于 2014-4-23 23:38 编辑

这个问题张老师的视屏中有讲到
参数化类型与原始类型的兼容性:
参数化类型可以引用一个原始类型的对象,编译报告警告,例如, 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.                 c.add("5");//对于c 只能存String类型的 但可以指向一个原始类型对象
  9.                 Collection c1= new Vector<String>();//编译时也出警告
  10.                 c1.add(5);//对于c1 对象中声明的String类型表示这个对象可以接收String类型的,同时也可以接收其他类型的                //System.out.println(c1);
  11.                 //总结,能接收什么类型的对象,看左边,就是看这个对象的类型上面有没有参数化
  12.         }

  13. }
复制代码
回复 使用道具 举报
NewDemo 来自手机 中级黑马 2014-4-23 23:34:42
沙发
你的第一种写法不严谨,一般如果加泛型的话等号两边都要加的
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马