泛型小结

因为刚开始学Java没多久,所有写的程序都是toy级的。用到泛型的时候唯一感觉就是泛型的使用可以对参数类别进行限制,省去了不少cast来cast去,或者一不小心甚至给错了参数类别,从而导致程序调来调去都不知道哪错了的问题。反正觉得泛型用起来蛮简单的。直到今天上完张孝祥老师的课,才对泛型有了比较系统的了解,感觉自己以前用到的也就是冰山一角。回来赶紧根据张老师的总结理解了一遍。

一:泛型的优点(1)写一个通用的函数,适应各种类型的参数;(2)操作数据为规定的数据类型,将程序的错误从运行时报错提前到编译期间;

二:泛型使用难点,也许对我自己来说是难点,对广大人民群众来说还是蛮easy的哈:

  a)参数化类型引用一个原始类型的对象,可以,报告警告

       Collection<String> c = new Vector();

  b)原始类型引用一个参数化类型的对象,可以,报告警告

       Collection c = new Vector<String>();

c)?通配置符

       有时候要定义一个泛型的引用变量,可以用“?”。例如Collection<?> collection。“?”的作用是适配所有的具有的引用变量类型;它是适配器,但是不能指定为任何一个具体的值,所以不能对与参数化有关的方法进行操作;下面的例子即可说明:

public static void printCollection(Collection<?> collection)

       {

              collection.add("string"); //错误,因为它不知自己未来匹配就一定是String

              collection = new HashSet<Date>();//正确,因为它能适配Date()

              collection.add(new Date());//错误,因为它不知自己未来匹配就一定是Date

              collection.size()//正确;

Collection<?> c = new Vector<String>();//正确;

       }

       d)向下限定通配符:

              正确:Vector<? extends Number> x = new Vector<Integer>();//<? extends Number>表示参数类型为NumberNumber的子类

              错误:Vector<? extends Number> x = new Vector<String>();

    向上限定通配符:

              正确:Vector<? super Integer> x = new Vector<Number>();//<? super Integer>表示为IntegerInteger的父类;

              错误:Vector<? super Integer> x = new Vector<Byte>();

其中,无论是向上,还是下,都包括自己。

三:泛型的种类:(1)普通的泛型 例如:ArrayList<String> arrayList = new ArrayList<String>();

2)方法级的泛型

可以根据参数的类型来决定泛型的类型,可以根据返回值来决定参数类型,构造方法和静态方法中都可以使用泛型

3)类级的泛型;类中的多处都要用到同一个类型,这时候就要用类级别的泛型;例如数据库Employee表中中对Manager类,Analyst类的操作等;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值