Java泛型继承

谁践踏了优雅 2021-09-20 12:32 397阅读 0赞

一 点睛

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

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

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

  1. public class A1 extends Apple<String> {
  2. // 正确重写了父类的方法,返回值
  3. // 与父类Apple<String>的返回值完全相同
  4. public String getInfo() {
  5. return "子类" + super.getInfo();
  6. }
  7. /*
  8. // 下面方法是错误的,重写父类方法时返回值类型不一致
  9. public Object getInfo()
  10. {
  11. return "子类";
  12. }
  13. */
  14. }

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

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

四 并不存在泛型类

1 点睛

  • 虽然可以把ArrayList类当成ArrayList的子类,事实上ArrayList类也确实是一种特殊的ArrayList类,这个ArrayList对象只能添加String对象作为集合元素。但实际上,系统并没有为ArrayList生成新的class文件,而且也不会把ArrayList当成新类来处理。
  • 实际上,泛型对其所有可能的类型参数,都具有同样的行为,从而可以把相同的类被当成许多不同的类来处理。与此完全一致的是,类的静态变量和方法也在所有的实例间共享,所以在静态方法、静态初始化、或者静态变量的声明和初始化中不允许使用类型形参。
  • 系统中并不会真正生成泛型类,所以instanceof运算符后不能使用泛型类。

2 实战

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

发表评论

表情:
评论列表 (有 0 条评论,397人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Java继承

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