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