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]
相关推荐
靠沿14 小时前
Java数据结构初阶——LinkedList
java·开发语言·数据结构
Elias不吃糖15 小时前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
铁手飞鹰15 小时前
单链表(C语言,手撕)
数据结构·c++·算法·c·单链表
hweiyu0015 小时前
数据结构:循环链表
数据结构·链表
野蛮人6号16 小时前
力扣热题100道前62道,内容和力扣官方稍有不同,记录了本人的一些独特的解法
数据结构·算法·leetcode
学困昇16 小时前
C++11中的lambda表达式详解
开发语言·数据结构·c++
代码王同学17 小时前
数据结构:栈
数据结构
Cx330❀18 小时前
深入理解 C++ 哈希:从概念到实战应用
开发语言·数据结构·c++·算法·面试·哈希算法·散列表
小龙报18 小时前
《算法通关指南:数据结构和算法篇 --- 链表相关算法题》--- 1. 队列安排,2.约瑟夫问题
c语言·数据结构·c++·算法·创业创新·学习方法·visual studio
晨非辰19 小时前
算法闯关日记 Episode :解锁链表新副本——破解「相交」迷局与「回文」谜题
运维·数据结构·c++·人工智能·后端·深度学习·神经网络