225. Java 集合 - List接口 —— 记住顺序的集合

225. Java 集合 - List接口 ------ 记住顺序的集合


1. 🔹 List和普通Collection有什么区别?

在Java集合框架中,**List Collection**的一个子接口。 最大的不同在于: ✅ List会记住元素添加的顺序!

📌 具体区别总结

  • 普通Collection (例如Set)中,元素的顺序是不确定的。
  • List 中,元素的顺序是确定的 ------ 元素怎么添加进去,遍历时就怎么出来。

2. 🚀 遍历时顺序固定

当你使用 for-eachiterator() 遍历一个List时:

  • 第一个访问的元素,就是第一个添加的元素。
  • 第二个访问的元素,就是第二个添加的元素。
  • 以此类推,顺序永远一致

📢 注意:

  • 有些 Set 实现(比如 LinkedHashSet)也会"保持添加顺序",但这只是意外效果
  • 不要依赖Set的顺序行为 ,因为它不是Set接口的规范!

3. 🎯 List元素有索引

另一个重要的区别是:

  • 普通的Collection不能直接访问"第一个元素"或者"第二个元素"。
  • 而在List中,每个元素有一个明确的索引(index,从0开始编号。

因此,在List中你可以:

  • 按索引获取元素list.get(index)
  • 按索引插入元素list.add(index, element)
  • 按索引替换元素list.set(index, newElement)
  • 按索引删除元素list.remove(index)
  • 获取子列表list.subList(fromIndex, toIndex)

4. 🛠️ 示例:基本List操作

java 复制代码
import java.util.*;

public class ListExample {
    public static void main(String[] args) {
        List<String> cities = new ArrayList<>();

        // 添加元素
        cities.add("Beijing");
        cities.add("Shanghai");
        cities.add("Guangzhou");

        // 顺序遍历
        for (String city : cities) {
            System.out.println(city);
        }

        // 访问特定位置元素
        System.out.println("First city: " + cities.get(0)); // 输出:Beijing

        // 插入元素
        cities.add(1, "Shenzhen");
        System.out.println("After inserting Shenzhen: " + cities);

        // 替换元素
        cities.set(2, "Hangzhou");
        System.out.println("After replacing second city: " + cities);

        // 删除元素
        cities.remove(3);
        System.out.println("After removing city at index 3: " + cities);

        // 获取子列表
        List<String> subCities = cities.subList(0, 2);
        System.out.println("Sublist: " + subCities);
    }
}

运行输出:

java 复制代码
Beijing
Shanghai
Guangzhou
First city: Beijing
After inserting Shenzhen: [Beijing, Shenzhen, Shanghai, Guangzhou]
After replacing second city: [Beijing, Shenzhen, Hangzhou, Guangzhou]
After removing city at index 3: [Beijing, Shenzhen, Hangzhou]
Sublist: [Beijing, Shenzhen]

5. 🧠 小总结

特性 Collection List
是否保证元素顺序? 不保证 保证插入顺序
是否有索引? 没有 有,支持get/set/add(index)等
遍历元素顺序 不确定 确定
支持随机访问元素?

📌 小贴士

  • 可以举生活例子

    "想象一下,Collection像是一堆无序散落的信件,而List则像是一叠有编号的文件夹,顺序整整齐齐。"

  • 提个问题引导互动

    "如果我需要按添加顺序取回元素,还能随机访问第3个元素,我应该选Collection还是List?"】】、】

相关推荐
WeiXiao_Hyy12 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
苏渡苇18 分钟前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
吃杠碰小鸡29 分钟前
高中数学-数列-导数证明
前端·数学·算法
long31630 分钟前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
kingwebo'sZone34 分钟前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09011 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
rannn_1111 小时前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
我是伪码农1 小时前
Vue 2.3
前端·javascript·vue.js
短剑重铸之日1 小时前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
夜郎king2 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落