Java泛型概述

为什么用泛型

早期的Object类型可以接收任意的对象类型,但是在实际的使用中,会有类型转换的问题,也就存在隐患,所以Java提供泛型来解决这个安全问题

什么是泛型

泛型,即"参数化类型"

参数化类型,就是将类型有原来的具体的类型参数化,类似于方法中的变量参数

Java泛型(generics)是JDK 5 中引用的一个新特性,泛型提供了编译时类型安全检测机制,泛型的好处就是在编译的时候能够检查类型安全

泛型类

泛型类型用于类的定义中,被称为泛型类。通过泛型可以完成对一组类的操作对外开放相同的接口。

public class Demo{ / /T可以为任意标识符,常见的如T、E、K、V等形式的参数常用于表示泛型 private T key; / /key这个成员变量的类型为T,T的类型由外部指定 public Demo(T key) { / /泛型构造方法形参key的类型也为T,T的类型由外部指定 this.key = key; } public T getKey(){ / /泛型方法getKey的返回值类型为T,T的类型由外部指定 return key; } }

传入的实参类型需与泛型的类型参数类型相同,即为

Integer. Demo demo = new Demo(123456);

1.泛型的类型参数只能是类类型

2.泛型的类型参数可以有多个

3.如果没有定义具体类型,默认为Object

从泛型类派生子类

子类也是泛型类,子类和父类的泛型类型要一致

class A<T> extends Demo<T>

子类不是泛型类,父类也要明确泛型的数据类型

class A extends Demo<String>

泛型接口

泛型接口与泛型类的定义及使用基本相同。

public interface Demo<T>{定义一个泛型接口}

子类也是泛型类,子类和父类的泛型类型要一致

class A<T> implements Demo<T>{}

子类不是泛型类,父类要明确泛型的数据类型

public class A implements Demo<String>{}

通配符,上边界,下边界

类型通配符一般是使用"?"代替具体的类型实参

public void show(Demo<?> obj){//?表示实际传入的参数类型可以是任意的}

Demo<Integer> gInteger = new Demo<Integer>(123);

Demo<Number> gNumber = new Demo<Number>(456);

show(gInteger);

show(gNumber);

类型通配符上限

类/接口<? extends 实参类型>

要求该泛型的类型,只能是实参类型,或实参类型的子类类型。

类型通配符下限

类/接口<? super 实参类型>

要求该泛型的类型,只能是实参类型,或实参类型的父类类型。

类型擦除

泛型是Java 1.5版本才引进的概念,在这之前是没有泛型的,但是,泛型代码能够很好的和之前版本的代码兼容。那是因为,泛型到信息只存在与代码编译阶段,在进入JVM之前,与泛型相关的信息会被擦除掉,我们称之为类型擦除

泛型类被类型擦除后,相应的类型就被替换成Object类型或者上线类型。

案例: public class Demo{ T name; public Demo(T name) { this.name= name; } } Demo是一个泛型类,我们查看它在运行时的状态信息可以通过反射。

Demo demo= new Demo("jim");

Field f = eclz.getField(“name”);

System.out.println(f.getName()+" type:"+f.getType());

name type:java.lang.Object

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值