List特点和常用方法
List是有序、可重复的容器。
有序指的是:List中每个元素都有索引标记。可以根据元素的索引标记(在List中的位置)访问元素,从而精确控制这些元素。
可重复指的是:List允许加入重复的元素。更确切地讲,List通常允许满足e1.equals(e2) 的元素重复加入容器;
除了Collection接口中的方法,List多了一些跟顺序(索引)有关的方法:
方法 | 说明 |
void add (int index, Object element) | 在指定位置插入元素,以前元素通通后移一位 |
Object set (int index,Object element) | 修改指定位置的元素 |
Object get (int index) | 返回指定位置的元素 |
Object remove (int index) | 删除指定位置的元素,后面元素通通前移一位 |
int indexOf (Object o) | 返回第一个匹配元素的索引。如果没有该元素,返回-1 |
int lastIndexOf (Object o) | 返回最后一个匹配元素的索引。如果没有该元素,返回-1 |
List接口常用的实现类有3个:ArrayList、LinkedList、Vector。
【示例1】 List常用方法
public class TestList {
/** * 测试add/remove/size/isEmpty/contains/clear/toArrays等方法 */ public static void test01() { List<String> list = new ArrayList<String>();
System.out.println(list.isEmpty()); // true,容器里面没有元素 list.add("高淇"); System.out.println(list.isEmpty()); // false,容器里面有元素 list.add("高小七"); list.add("高小八");
System.out.println(list); System.out.println("list的大小:" + list.size()); System.out.println("是否包含指定元素:" + list.contains("高小七")); list.remove("高淇"); System.out.println(list);
Object[] objs = list.toArray(); System.out.println("转化成Object数组:" + Arrays.toString(objs));
list.clear(); System.out.println("清空所有元素:" + list); }
public static void main(String[] args) { test01(); } } |
示例1 运行效果图
【示例2】 List中多个容器操作方法
public class TestList {
public static void main(String[] args) { test02(); } /** * 测试两个容器之间元素处理 */ public static void test02(){ List<String> list = new ArrayList<String>(); list.add("高淇"); list.add("高小七"); list.add("高小八");
List<String> list2 = new ArrayList<String>(); list2.add("高淇"); list2.add("张三"); list2.add("李四");
System.out.println(list.containsAll(list2)); //false list是否包含list2中所有元素 System.out.println(list);
// list.addAll(list2); //将list2中所有元素都添加到list中 // System.out.println(list);
// list.removeAll(list2); //从list中删除同时在list中存在的元素 // System.out.println(list);
list.retainAll(list2); //取list和list2的交集 System.out.println(list);
} } |
【示例3】 测试List中索引操作常用方法
public class TestList { public static void main(String[] args) { test03(); } /** * 测试List中关于索引操作的方法 */ public static void test03(){ List<String> list = new ArrayList<String>(); list.add("A"); list.add("B"); list.add("C"); list.add("D");
System.out.println(list); //[A, B, C, D]
list.add(2,"高"); System.out.println(list); //[A, B, 高, C, D]
list.remove(2); System.out.println(list); //[A, B, C, D]
list.set(2, "c"); System.out.println(list); //[A, B, c, D]
System.out.println(list.get(1)); //返回:B
list.add("B"); System.out.println(list); //[A, B, c, D, B]
System.out.println(list.indexOf("B")); //1 从头到尾找到第一个"B" System.out.println(list.lastIndexOf("B")); //4 从尾到头找到第一个"B" } } |
示例3 运行效果图
下节,我们继续深入讨论「List接口常用实现类的特点和底层实现」。
「全栈Java笔记」是一部能帮大家从零到一成长为全栈Java工程师系列笔记。笔者江湖人称 Mr. G,10年Java研发经验,曾在神州数码、航天院某所研发中心从事软件设计及研发工作,从小白逐渐做到工程师、高级工程师、架构师。精通Java平台软件开发,精通JAVAEE,熟悉各种流行开发框架。
笔记包含从浅入深的六大部分:
A-Java入门阶段
B-数据库从入门到精通
C-手刃移动前端和Web前端
D-J2EE从了解到实战
E-Java高级框架精解
F-Linux和Hadoop