List<Integer> list=new ArrayList<>()

List<Integer> list = new ArrayList<>(); 是 Java 中创建泛型列表的常见语法,下面详细解释其含义和关键点:

1. 代码拆解

sql 复制代码
List<Integer> list = new ArrayList<>();
  • List<Integer>

    • 接口类型List 是 Java 集合框架中的接口,定义了有序、可重复的集合操作(如添加、删除、索引访问等)。
    • 泛型参数 <Integer> :指定列表中只能存储 Integer 类型的对象(即整数的包装类)。使用泛型后,编译器会自动检查类型安全,避免运行时的 ClassCastException
  • new ArrayList<>()

    • 实现类ArrayListList 接口的动态数组实现,支持自动扩容。
    • 菱形语法 <>:Java 7 引入的语法糖,允许省略右侧的泛型参数(编译器会根据左侧类型自动推断)。

2. 关键点说明

2.1 泛型的作用
  • 类型安全

    java 复制代码
    list.add(10);     // 合法:自动装箱 int → Integer
    list.add("hello"); // 编译错误:类型不匹配

    无需手动类型转换

    java 复制代码
    Integer num = list.get(0); // 直接获取 Integer 类型,无需强制转换
    2.2 动态数组特性
  • ArrayList 会自动扩容,初始容量为 10,超过容量时会创建更大的数组并复制元素。

  • 缺点:插入 / 删除操作效率较低(需移动元素),适合随机访问场景。

2.3 多态的应用
  • 面向接口编程 :变量声明为 List 接口类型,而非具体实现类 ArrayList,便于后续更换实现(如改用 LinkedList)。

    java 复制代码
    // 可无缝切换为 LinkedList
    List<Integer> list = new LinkedList<>();

    3. 常见操作示例

    java 复制代码
    // 添加元素
    list.add(10);       // [10]
    list.add(20);       // [10, 20]
    list.add(1, 15);    // 在索引 1 插入 15 → [10, 15, 20]
    
    // 获取元素
    Integer first = list.get(0); // 10
    
    // 遍历
    for (Integer num : list) {
        System.out.println(num);
    }
    
    // 删除元素
    list.remove(1);    // 删除索引 1 的元素 → [10, 20]
相关推荐
浅念-8 小时前
LeetCode 回溯算法题——综合练习
数据结构·c++·算法·leetcode·职场和发展·深度优先·dfs
生成论实验室15 小时前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
阿文的代码库15 小时前
线段树入门:算法分析
数据结构·算法
悠仁さん16 小时前
数据结构 树 二叉树 堆 (堆的模拟实现篇)
数据结构
此生决int16 小时前
算法从入门到精通——位运算
数据结构·c++·算法·蓝桥杯
计算机安禾16 小时前
【算法分析与设计】第4篇:分治策略的理论框架与经典案例
数据结构·算法·排序算法
Kiling_070416 小时前
面向对象和集合编程题 ( 二 )
java·开发语言·数据结构·算法
过期动态16 小时前
【LeetCode 热题 100】两数之和— 暴力法与哈希表法详解
java·数据结构·算法·leetcode·散列表
Pointer Pursuit16 小时前
哈希表的实现
数据结构·哈希算法·散列表
故事和你9117 小时前
洛谷-【动态规划1】动态规划的引入4
开发语言·数据结构·c++·算法·动态规划·图论