千锋学堂Java培训之泛型继承原理与用法详解

2019-07-31 15:40:20 2709浏览

今天千锋扣丁学堂Java培训老师给大家分享一篇关于Java泛型继承原理与用法详解,结合实例形式分析了java泛型继承的相关原理与实现技巧,下面我们一起来看一下吧。



一、点睛


当创建了带泛型声明的接口、父类之后,可以为该接口创建实现类,或从该父类来派生子类,但值得指出的是,当使用这些接口、父类时不能再包含类型形参。

如果使用泛型类时没有传入实际的类型参数,Java编译器可能发出警告:使用了未经检查或不安全的操作——这就是泛型检查的警告。

二、实战——传入实际的类型参数


public class A1 extends Apple<String> {
  // 正确重写了父类的方法,返回值
  // 与父类Apple<String>的返回值完全相同
  public String getInfo() {
    return "子类" + super.getInfo();
  }
  /*
  // 下面方法是错误的,重写父类方法时返回值类型不一致
  public Object getInfo()
  {
   return "子类";
  }
  */
}

三、实战——没传入实际的类型参数

public class A2 extends Apple {
  // 重写父类的方法
  public String getInfo() {
    // super.getInfo()方法返回值是Object类型,
    // 所以加toString()才返回String类型
    return super.getInfo().toString();
  }
}

四、并不存在泛型类

1点睛

虽然可以把ArrayList<String>类当成ArrayList的子类,事实上ArrayList<String>类也确实是一种特殊的ArrayList类,这个ArrayList<String>对象只能添加String对象作为集合元素。但实际上,系统并没有为ArrayList<String>生成新的class文件,而且也不会把ArrayList<String>当成新类来处理。

实际上,泛型对其所有可能的类型参数,都具有同样的行为,从而可以把相同的类被当成许多不同的类来处理。与此完全一致的是,类的静态变量和方法也在所有的实例间共享,所以在静态方法、静态初始化、或者静态变量的声明和初始化中不允许使用类型形参。

系统中并不会真正生成泛型类,所以instanceof运算符后不能使用泛型类。

2实战

public class R<T>
{
  // 下面代码错误,不能在静态变量声明中使用类型形参
// static T info;
  T age;
  public void foo(T msg){}
  // 下面代码错误,不能在静态方法声明中使用类型形参
// public static void bar(T msg){}
}

以上就是关于千锋学堂Java培训之泛型继承原理与用法详解的全部内容,希望本文所述对大家java程序设计有所帮助,想要了解更多关于Java方面内容的小伙伴,请关注扣丁学堂Java培训官网、微信等平台,扣丁学堂IT职业在线学习教育平台为您提供权威的Java开发视频,Java培训后的前景无限,行业薪资和未来的发展会越来越好的,扣丁学堂老师精心推出的Java视频教程定能让你快速掌握Java从入门到精通开发实战技能。扣丁学堂Java技术交流群:850353792。


                          JavaEE/微服务/源码解析/分布式/企业级架构【VIP体验课】


     【关注微信公众号获取更多学习资料】        【扫码进入JavaEE/微服务VIP免费公开课】  



查看更多关于“Java开发资讯”的相关文章>>

标签: Java培训 Java视频教程 Java多线程 Java面试题 Java学习视频 springBoot项目

热门专区

暂无热门资讯

课程推荐

微信
微博
15311698296

全国免费咨询热线

邮箱:codingke@1000phone.com

官方群:148715490

北京千锋互联科技有限公司版权所有   北京市海淀区宝盛北里西区28号中关村智诚科创大厦4层
京ICP备12003911号-6   Copyright © 2013 - 2019

京公网安备 11010802030908号