现在的位置: 首页 > 综合 > 正文

黑马程序员—泛型的学习2

2013年04月05日 ⁄ 综合 ⁄ 共 2275字 ⁄ 字号 评论关闭

---------------------- android培训java培训、期待与您交流! ----------------------

 自动解包装与自动包装的功能

  从上面有没有看到有点别扭啊,h.get(new Integer(123))这里的new Integer(123);好烦的,在JDK5.0之前我们只能忍着了,现在这种问题已经解决了,请看下面这个方法。我们传入一个int这一基本型别,然后再将i的值直接添加到List中,其实List是不能储存基本型别的,List中应该存储对象,这里编译器将int包装成Integer,然后添加到List中去。接着我们用List.get(0);来检索数据,并返回对象再将对象解包装成int。JDK5.0给我们带来更多方便与安全。

1、由C++的模板函数引入自定义泛型,如下函数的结构很相似,仅类型不同:
        int add(int x, int y) { return x + y;}
        float add(float x, float y) { return x + y;}
        double add(double x ,double y) {return x + y;}
    2C++用模板函数解决,只写一个通用方法,它可以适应各种类型,示意代码如下:
        T add(T x, T y) {return (T) (x + y);}
    3、泛型是提供给Javac编译器使用的。可以限定集合中输入的类型,让编译器挡住原始程序的非法输入,编译器编译带类型说明的集合时会去掉类型信息,使程序运行效率不受影响,对于参数化的泛型类型,getClass()方法的返回值和原始类型完全一样,由于编译生成的字节码会去掉泛型的类型信息,只要能跳过编译器,就可以往某个泛型集合中加入其它类型的数据,例如,用反射得到集合,再调用其add方法即可。
37_黑马程序员_张孝祥_Java基础加强_泛型的内部原理及更深应用
ArrayList<String> 和 ArrayList<Integer> 都是同一类型class
    1、泛型是给javac编译器使用的,可以限定类型,但是编译的class会去掉类型信息,使效率不影响,所以可以使用反射来添加其他类型
    2ArayList<E>类定义和ArrayList<Integer>类引用中涉及如下术语
        整个称为ArrayList<E>泛型类型
        ArrayList<E>中的E称为类型变量或类型参数
        整个ArrayList<Integer>称为参数化的类型
        ArrayList<Integer>中的Integer称为类型参数的实例或实际类型参数
        ArrayList<Integer>中的<>typeof
        ArrayList 称为原始类型
    3、参数化类型与原始类型的兼容性
        参数化类型可以引用一个原始类型的对象,编译报警,
        Collection<String> c = new Vector()
        原始类型可以引用一个参数化类型的对象,编译报警
        Collection c = new Vector<String>()
    4、参数化类型不考虑类型的继承关系
        Collection<String> c = new Vector<Object>() 
        Collection<Object> c = new Vector<String>() 
    5、再创建数组实例时,数组的元素不能使用参数化类型,
        Vector<Integer> vectorList[] = new Vector<Integer>[10]
    6、思考
        Vector v1 = new Vector<String>(); 编译报警
        Vctor<Object> v = v1; 编译报警,运行错

 参数化类型与原始类型的兼容性:
 参数化类型可以引用一个原始类型的对象,编译报告警告,例如,
  Collection<String> c = new Vector ();

原始类型可以引用一个参数化类型的对象,编译报告警告,例如,
  Collection c = new Vector<String>();

参数化类型不考虑类型参数的继承关系:
  Vector<String> v = new Vector<Object>(), 错误
  Vector<Object> v = new Vector<String>(),也错误。

泛型中的 ? 通配符的扩展

限定通配符的上边界:
正确: Vector<? extends Number> x = new Vector<Integer>();
错误: Vector<? extends Number> x = new Vector<String>();

限定通配符的下边界:
正确: Vector<? super Integer> x = new Vector<Number>();
错误: Vector<? super Integer> x = new Vector<Byte>();

提示: 限定通配符总是包括自己。

 

---------------------- android培训java培训、期待与您交流! ---------------------- 

详细请查看:http://edu.csdn.net/heima 

抱歉!评论已关闭.