Java泛型深入研究.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java泛型深入研究 ?实际上泛型可以用得很复杂,复杂到编写代码的人员自己也难以看懂。这往往是对泛型的滥用或者类或接口本身设计不合理导致的。 看来用好泛型还真不容易,为此必须从根源说起。 ? 一、逐渐深入泛型 1、没有任何重构的原始代码: 有两个类如下,要构造两个类的对象,并打印出各自的成员x。 public class StringFoo { ??? private String x; ? ??? public StringFoo(String x) { ??????? this.x = x; ??? } ??? ??? public String getX() { ??????? return x; ??? } ? ??? public void setX(String x) { ??????? this.x = x; ??? } } ? public class DoubleFoo { ??? private Double x; ? ??? public DoubleFoo(Double x) { ??????? this.x = x; ??? } ? ??? public Double getX() { ??????? return x; ??? } ? ??? public void setX(Double x) { ??????? this.x = x; ??? } } ? 以上的代码是在无聊,就不写如何实现了。 ? 2、对上面的两个类进行重构,写成一个类: 因为上面的类中,成员和方法的逻辑都一样,就是类型不一样,因此考虑重构。Object是所有类的父类,因此可以考虑用Object做为成员类型,这样就可以实现通用了,实际上就是“Object泛型”,暂时这么称呼。 ? public class ObjectFoo { ??? private Object x; ? ??? public ObjectFoo(Object x) { ??????? this.x = x; ??? } ? ??? public Object getX() { ??????? return x; ??? } ? ??? public void setX(Object x) { ??????? this.x = x; ??? } } ? 写出Demo方法如下: public class ObjectFooDemo { ??? public static void main(String args[]) { ??????? ObjectFoo strFoo = new ObjectFoo(Hello Generics!); ??????? ObjectFoo douFoo = new ObjectFoo(new Double(33)); ??????? ObjectFoo objFoo = new ObjectFoo(new Object()); ? ??????? System.out.println(strFoo.getX=+(String)strFoo.getX()); ??????? System.out.println(douFoo.getX=+(Double)douFoo.getX()); ??????? System.out.println(objFoo.getX=+(Object)objFoo.getX()); ??? } } ? 运行结果如下: ? strFoo.getX=Hello Generics! douFoo.getX=33.0 objFoo.getX=java.lang.Object@19821f ? 解说:在Java 5之前,为了让类有通用性,往往将参数类型、返回类型设置为Object类型,当获取这些返回类型来使用时候,必须将其“强制”转换为原有的类型或者接口,然后才可以调用对象上的方法。 ? 3、Java5泛型来实现 ?????强制类型转换很麻烦,我还要事先知道各个Object具体类型是什么,才能做出正确转换。否则,要是转换的类型不对,比如将“Hello Generics!”字符串强制转换为Double,那么编译的时候不会报错,可是运行的时候就挂了。那有没有不强制转换的办法----有,改用 Java5泛型来实现。 ? public class GenericsFooT { ??? private T x; ? ??? public GenericsFoo(T x) { ??????? this.x = x; ??? } ? ??? public T getX() { ??????? return x; ??? } ? ??? public void setX(T x) { ??????? this.x = x

文档评论(0)

***** + 关注
实名认证
文档贡献者

本账号下所有文档分享可拿50%收益 欢迎分享

1亿VIP精品文档

相关文档