Java下的Framework编写(2)--泛型的应用

        JDK5.0支持泛型后,Collection类便集体换装,好处一是Collction的调用者不用再对返回值进行显式的转换,二是获得了编译期的类型安全。
      除了应用Collecton的泛型特性外,JDK5.0还允许我们编写 自己的泛型类
     我就理所当然的期望,通过应用泛型,能够让框架获得比上面两点更多的好处。但用过一阵子之后一总结,发现因为著名的擦拭法,因为拿不到 T.class,也就不可以 从T来newInstance(),泛型在框架内的表现,仍然只能带来以上两个优点。

  一,调用者不用对返回值进行显式转换。
          不过对于抠门的Programer来说,这点还要计算一下,搞不好省了一个地方的显式转换,却多了三四个地方要显式定义泛型。
          不过泛型有个好的地方是,如果调用者不显式定义<T>,那用T定义的地方会自动转回Object,如果T是用<T extends FooClass>定义的,就自动转回FooClass,和你不用泛型时的结果一样。
          所以,作为框架,应该提供这个使用泛型与否的选择给用户。合不合算由调用者自己决定和选择。

二,编译期的类型检查
        是编译期,对于越多越多使用反射和hashMap进行晚绑定,离类型安全越来越远的java来说,T和Class<T>的限制是个不错的救赎。

  仍然在想有没有第3个好处。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值