当前位置: 首页 > news >正文

Java泛型 的详细知识总结

一、泛型的核心作用

  1. 类型安全:在编译期检查类型匹配,避免运行时的ClassCastException
  2. 代码复用:通过泛型逻辑统一处理多种数据类型。
  3. 消除强制转换:减少显式的类型转换代码。

二、泛型基础语法

1. 泛型类/接口
  • 定义:在类/接口名后添加类型参数<T>T为占位符类型。
     

    <JAVA>

    public class Box<T> {private T content;public void set(T content) { this.content = content; }public T get() { return content; }
    }
    
2. 泛型方法
  • 定义:在方法返回类型前声明泛型类型。
     

    <JAVA>

    public <T> void printArray(T[] array) {for (T element : array) {System.out.print(element + " ");}
    }
    
3. 泛型通配符 ?
  • 作用:表示未知类型,增强灵活性。
    • 上界通配符 <? extends T>:接受T及其子类。
       

      <JAVA>

      // 接受Number或其子类(如Integer/Double)的列表
      public void process(List<? extends Number> list) { /* ... */ }
      
    • 下界通配符 <? super T>:接受T及其父类。
       

      <JAVA>

      // 接受Integer或其父类(如Number/Object)的列表
      public void addNumbers(List<? super Integer> list) { list.add(42); }
      

三、泛型深入原理

1. 类型擦除(Type Erasure)
  • 原理:编译期将泛型类型替换为原始类型(如Object或上界类型),并在必要时插入类型转换。
    • 擦除示例:
       

      <JAVA>

      // 源码
      List<String> list = new ArrayList<>();
      String s = list.get(0);// 编译后的等效代码(类型擦除)
      List list = new ArrayList();       // 类型擦除为原始类型List
      String s = (String) list.get(0);   // 插入强制转换
      
2. 桥方法(Bridge Method)
  • 作用:确保泛型类在继承和多态中能正确调用类型擦除后的方法。
  • 示例:泛型类继承时,编译器自动生成桥方法保持多态性。

四、泛型应用场景

1. 集合框架
  • 泛型在集合中的典型应用:
     

    <JAVA>

    List<String> names = new ArrayList<>();  // 安全存储字符串
    Map<Integer, String> idToName = new HashMap<>();
    
2. 通用工具类/方法
  • 编写与具体类型解耦的工具逻辑:
     

    <JAVA>

    public static <T> T getFirst(List<T> list) {return list.isEmpty() ? null : list.get(0);
    }
    
3. 回调接口
  • 定义泛型回调接口:
     

    <JAVA>

    public interface Callback<T> {void onSuccess(T result);void onFailure(String error);
    }
    
4. 泛型与反射
  • 通过反射获取泛型实际类型(需借助ParameterizedType):
     

    <JAVA>

    Type type = new TypeToken<List<String>>(){}.getType();  // Guava库常用
    

五、泛型限制与注意事项

  1. 类型参数不能是基本类型

     

    <JAVA>

    // 错误示例
    List<int> list = new ArrayList<>();  // 需使用包装类Integer
    
  2. 无法实例化泛型类型

     

    <JAVA>

    T instance = new T();  // 编译错误
    
  3. 静态成员不能使用类型参数

     

    <JAVA>

    class Box<T> {// static T data;  // 错误
    }
    
  4. 泛型数组的限制

     

    <JAVA>

    // 不能直接创建泛型数组
    // T[] array = new T[10];  // 错误
    // 可通过反射或强制类型转换实现(存在风险)
    T[] array = (T[]) new Object[10];
    
  5. 泛型与异常

    • 不能抛出或捕获泛型类的实例。
    • 泛型类不能直接或间接继承Throwable

六、高级泛型特性

1. 递归类型边界(Recursive Type Bound)
  • 限制类型参数为当前类的子类:
     

    <JAVA>

    public class Node<T extends Comparable<T>> {// T必须实现Comparable<T>接口
    }
    
2. 类型推断(Type Inference)
  • 编译器自动推导泛型类型:
     

    <JAVA>

    List<String> list = Collections.emptyList();  // Java 7+可推断为List<String>
    

七、常见问题与解决方案

  1. 如何获取泛型的实际类型?

    • 通过子类化TypeToken(Guava库)或反射捕获类型:
       

      <JAVA>

      Type type = ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
      
  2. 何时使用ListList<?>

    • List:原始类型(存在类型不安全警告)。
    • List<?>:未知类型的集合(只能读取为Object,不能添加元素)。

总结

泛型是Java类型系统的核心机制,通过合理使用可大幅提升代码的安全性和可维护性。重点需掌握:

  • 通配符的上下界用于灵活设计API;
  • 类型擦除理解底层限制;
  • 泛型与集合、工具类的结合提升代码复用率。

相关文章:

  • 【C# 自动化测试】Selenium显式等待机制详解
  • 考研系列-408真题计算机组成原理篇(2020-2023)
  • 如何利用 Java 爬虫根据 ID 获取某手商品详情:实战指南
  • Docker-Harbor 私有镜像仓库使用指南
  • 小白编程学习之巧解「消失的数字」
  • 2025年JIII SCI1区TOP,多策略霜冰优化算法IRIME+无人机路径规划,深度解析+性能实测
  • (2)JVM 内存模型更新与 G1 垃圾收集器优化
  • 电子科技大学软件工程实践期末
  • USB转TTL
  • 智能笔记助手-NotepadAI使用指南
  • 多线程(六)
  • RFID智能书柜:阅读新时代的智慧引擎
  • doris数据分片逻辑
  • Stack Queue
  • 跳空高低开策略思路
  • 蓝桥杯框架-按键数码管
  • Map更简洁的编码构建
  • 【Linux】48.高级IO(2)
  • vs2017编译ncnn库
  • PostgreSQL架构
  • 中沙深化多领域合作,达成60余项共识
  • 马上评|把孩子当牟利工具,这样的流量吃不得
  • 西安集中整治监督教育领域不正之风和腐败问题,举报方式公布
  • 外交部:巴基斯坦副总理兼外长达尔5月19日至21日访华
  • 专利申请全球领先!去年我国卫星导航与位置服务产值超5700亿元
  • 广东缉捕1名象牙走私潜逃非洲“红通”逃犯