java基础 —— 泛型

目录

1. 概念

2. 从泛型派生子类

  1. 子类和父类都是泛型类

2. 子类不是泛型类,明确父类类型

3. 泛型接口

4. 泛型通配符

1. 泛型类型的上限

2. 泛型类型的下限

5. 类型擦除


目的:解决类型转换的安全问题,因为object在进行类型转换中,存在隐患。

例在需要时,向下转型,会出现转型异常;java中希望集合存储同一类型的数据,使用泛型,在创建对象的时候,把类型当做参数传递进去,已明确其类型。

1. 概念

泛型:参数化类型(把类型当做参数传进去)

注:没有进行设置类型,默认为Object 类型

//public class CommonResult<T,E> 可以传递多个参数
public class CommonResult<T> {
    private   int code;
    private  String message;
    private   T data;
    public int getCode() {
        return code;
    }
​
    public void setCode(int code) {
        this.code = code;
    }
​
    public String getMessage() {
        return message;
    }
​
    public void setMessage(String message) {
        this.message = message;
    }
​
    public T getData() {
        return data;
    }
​
    public void setData(T data) {
        this.data = data;
    }
}
public class Test {
    public static void main(String[] args) {
        CommonResult c = new CommonResult();
        c.setData("");//默认为object类型
        CommonResult<String> cr = new CommonResult<String>();//把类型作为参数传递进去
        cr.setData("c");//String类型
    }
}

2. 从泛型派生子类

  1. 子类和父类都是泛型类

DemoAChild<String> dc = new DemoAChild();

创建子类对象时传入类型,父类类型与子类类型一致

 public class DemoAChild<T> extends DemoA<T>{
​
}

2. 子类不是泛型类,明确父类类型

   如果子类不是泛型类,那么明确父类类型

    DemoAChild dc = new DemoAChild();
public class DemoAChild extends DemoA<String>{}
public class Person implements Comparable<Person>{
    private int id;
    private String name;
public int getId() {
    return id;
}
​
public void setId(int id) {
    this.id = id;
}
​
public String getName() {
    return name;
}
​
public void setName(String name) {
    this.name = name;
}
​
public Person(int id, String name) {
    this.id = id;
    this.name = name;
}
​
@Override
public int compareTo(Person o) {
   return this.id - o.id;//        return this.name.compareTo(o.name);
    }
Override
public String toString() {
    return "Person{" +
            "id=" + id +
            ", name='" + name + '\'' +
            '}';
}
}

因为子类如果不是泛型类,创建子类对象时不能传入类型,父类类型也就无法明确
 

3. 泛型接口

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

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

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

Person类实现了一个泛型接口,Person类不是泛型类,所有Comparable接口就需要明确类型

Person类实现了一个泛型接口,Person类不是泛型类,所有Comparable接口就需要明确类型
public class Person implements Comparable<Person>{
    private int id;
    private String name;
public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public Person(int id, String name) {
    this.id = id;
    this.name = name;
}

@Override
public int compareTo(Person o) {
   return this.id - o.id;//        return this.name.compareTo(o.name);
    }
Override
public String toString() {
    return "Person{" +
            "id=" + id +
            ", name='" + name + '\'' +
            '}';
}
}

4. 泛型通配符

    ? 类型通配符(任意的),用来定义表示实际参数的类型

1. 泛型类型的上限<? extends 类型>

          只能传入类型以及类型的子类

public class DemoB<T> {
     private T date;
     public void test(DemoB<? extends Number> db){
​
    }
​
    public static void main(String[] args) {
        DemoB<Integer> di = new DemoB<>();
        DemoB<Number> dn = new DemoB<>();
        di.test(di);
        dn.test(dn);
    }
}

2. 泛型类型的下限<? super 类型>

         只能传入类型以及类型的父类

         例:<? super Number> 只能传入Number类型 以及 Number的父类

public class DemoB<T> {
     private T date;
​
    public void test(DemoB<? super Number> db){
​
    }
​
    public static void main(String[] args) {
        DemoB<Object> di = new DemoB<>();
        DemoB<Number> dn = new DemoB<>();
        di.test(di);
        dn.test(dn);
    }
  } 

5. 类型擦除

         泛型是jdk1.5之后的语法,以前的版本还不支持,所以底层还是使用Object作为类型 泛型的主要作用是在编译期间对类型进行明确的, 这个就叫类型擦除

import java.lang.reflect.Field;
import java.util.ArrayList;
​
public class Demo3 {
​
    public static void main(String[] args) throws NoSuchFieldException, SecurityException {
        ArrayList<String> list =  new ArrayList<>();
​
        Class c = list.getClass();
        Field f = c.getDeclaredField("elementData");
        System.out.println(f.getName()+"::"+f.getType());
​
​
    }
​
}
​

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java静态属性泛型是指在Java中,我们可以在静态属性上使用泛型类型。通过在静态属性的类型声明中添加泛型参数,我们可以在静态属性中使用泛型类型,从而使静态属性具有泛型的特性。 举例来说,我们可以定义一个拥有泛型类型的静态属性,如下所示: public class MyClass<T> { public static T staticField; } 在上面的例子中,我们通过在静态属性staticField的类型声明中添加了泛型参数T,使得静态属性具有泛型的特性。这样,我们就可以根据实际情况在不同地方使用不同类型的静态属性。 需要注意的是,在静态属性中使用泛型类型时,由于静态属性属于类而不是对象,所以泛型类型参数不能是实例化类型,而必须是类级别的类型。也就是说,不能使用泛型类型参数T来实例化静态属性,而只能使用具体的类型来实例化。 因此,使用静态属性时,我们需要确保在静态属性的类型声明中正确地使用泛型类型参数,并在使用时传入具体的类型来实例化静态属性。这样,就可以在静态属性中使用泛型类型了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Java 中的泛型(两万字超全详解)](https://blog.csdn.net/weixin_45395059/article/details/126006369)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值