java传入所有对象泛型_Java之泛型继承原理与用法详解

221186be7e0323832406f043082b668b.png

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){}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值