String[ ] 和 List<String> 的区别

今天在开发的时候,碰到一个业务场景,要给不同的标题,赋予不同的颜色(固定浅色系)。

一、基本概念

项目 String[] List<String>
类型 数组(Array) 集合(Collection)
所在包 Java 基础类型(无须导包) java.util.List
大小 固定长度 可动态增删
存储 连续内存块 由 List 接口 + 动态数组或链表实现
主要实现类 无(数组是原生类型) ArrayList, LinkedList
定义方式 String[] arr = {"A", "B"}; List<String> list = Arrays.asList("A", "B");new ArrayList<>()
可变性 长度固定、元素可改 长度可变、元素可改(可增删)

二、示例对比

1. 定义方式

复制代码
// 数组
String[] colorsArray = {"red", "blue", "green"};

// List
List<String> colorsList = new ArrayList<>();
colorsList.add("red");
colorsList.add("blue");
colorsList.add("green");

2. 添加元素

复制代码
// ❌ 数组长度固定,不能直接添加
colorsArray[3] = "yellow"; // 报错:数组越界

// ✅ List 可以随时添加
colorsList.add("yellow");

3. 删除元素

复制代码
// ❌ 数组不能删除,只能手动创建新数组
String[] newArray = Arrays.copyOf(colorsArray, colorsArray.length - 1);

// ✅ List 直接删除
colorsList.remove("blue");

4. 遍历方式

两者都能用增强 for 循环:

复制代码
for (String color : colorsArray) { ... }
for (String color : colorsList) { ... }

5. 转换方式

数组 → List

复制代码
String[] arr = {"A", "B", "C"};
List<String> list = Arrays.asList(arr); // 注意:返回的 List 长度固定

List → 数组

复制代码
List<String> list = List.of("A", "B", "C");
String[] arr = list.toArray(new String[0]);

6. 内存与性能

  • 数组:固定大小、连续内存,性能略高;

  • List :更灵活,但底层可能会自动扩容(尤其是 ArrayList),开销稍高。


三、使用建议

场景 推荐使用
数据数量固定、不需要增删 String[]
需要频繁添加、删除、修改元素 List<String>
要与 Stream、Collections 等工具类配合 List<String>
要节省内存、追求性能极限 String[](比如算法题)

四、快速总结一句话

String[] 是固定长度的容器,性能高但死板;
List<String> 是可变长度的集合,灵活强大、现代开发首选。

相关推荐
wifi chicken33 分钟前
Linux 内核开发之单链表的增删查改详解
linux·数据结构·链表
im_AMBER2 小时前
数据结构 18 【复习】广义表 | 各种内部排序 | 二叉排序树的平均查找长度 ASL
数据结构·笔记·学习·排序算法
leaves falling5 小时前
冒泡排序(基础版+通用版)
数据结构·算法·排序算法
C雨后彩虹5 小时前
无向图染色
java·数据结构·算法·华为·面试
程序员-King.5 小时前
二分查找——算法总结与教学指南
数据结构·算法
Xの哲學5 小时前
Linux自旋锁深度解析: 从设计思想到实战应用
linux·服务器·网络·数据结构·算法
好奇龙猫6 小时前
【大学院-筆記試験練習:线性代数和数据结构(9)】
数据结构·线性代数
0和1的舞者6 小时前
力扣hot100-链表专题-刷题笔记(一)
数据结构·链表·面试·刷题·知识
難釋懷6 小时前
Redis数据结构介绍
数据结构·数据库·redis
Pluchon7 小时前
硅基计划4.0 算法 优先级队列
数据结构·算法·排序算法