Java容器——List接口
1. 定义
List是Collection的子接口,元素有序并且可以重复,表示线性表。
2. 常用实现类
ArrayList:它为元素提供了下标,可以看作长度可变的数组,为顺序线性表。
LinkedList:通过代价较低的在List中间进行插入和删除操作,提供了优化的顺序访问,但是在随即访问方面相对比较慢,为链表线性表。
3. 方法
boolean add(E e):在列表末添加元素
void add(int index, E e):在指定索引处添加元素,不会覆盖原先元素
boolean addAll(int index, Collection e):在指定索引处放入集合
Object get(int index):获取指定索引的元素
E set(int index, E element):更新指定索引的元素
int indexOf(Object o):获取指定元素在集合中的索引(第一次出现的元素)
int lastIndexOf(Object o):返回此列表中最后出现的元素的索引
Object remove(int index):删除指定索引对应的元素
boolean remove(Object o):删除列表中出现的第一个指定元素
boolean contains(Object o):判断列表是否包含给定元素
List subList(int fromIndex, int toIndex):返回索引为[form,to)的元素集合
Object[] toArray():将列表转为数组
Iterator<E> iterator():列表遍历的迭代器
boolean isEmpty():判断列表是否为空
void clear():删除列表所有元素
int size():返回列表长度
其他方法及其具体说明:https://docs.oracle.com/javase/8/docs/api/
4.示例
import java.util.*;
public class ListFunc {
public static void main(String[] args){
List<String> list1 = new ArrayList<>();
//在列表末尾添加元素
list1.add("1");
list1.add("2");
list1.add("3");
list1.add("4");
// 在列表指定索引处添加元素
list1.add(1,"2");
list1.add(5,"5");
list1.add(6,"6");
System.out.println(list1); // [1, 2, 2, 3, 4, 5, 6]
//删除指定索引的元素
list1.remove(0);
System.out.println(list1); // [2, 2, 3, 4, 5, 6]
//删除指定元素(第一个),要删除的元素可以不在列表中
list1.remove("2");
System.out.println(list1); //[2, 3, 4, 5, 6]
//删除指定索引区域的多个元素
// subList = list1.subList(1,3);
// subList.clear(); // 两者等价,更改subList会改变list1
list1.subList(1,3).clear();
System.out.println(list1); //[2, 5, 6]
//删除所有元素
// list1.clear();
// System.out.println(list1); //[]
// 更改指定索引的元素
list1.set(0,"1");
System.out.println(list1); // [1, 5, 6]
//获取指定索引处元素
String a1 = list1.get(0);
System.out.println(a1); // 1
// 获取指定元素的索引,没有该值返回-1
int index = list1.indexOf("1");
System.out.println(index); // 0
//获取指定索引区域的多个元素
List<String> list2 = list1.subList(0,2);
System.out.println(list2); // [1, 5]
// 判断列表是否有某元素
boolean flag = list2.contains("5");
System.out.println(flag); // true
// list转array
String[] arr2 = list2.toArray(new String[0]);
// String[] arr2 = list2.toArray(new String[list2.size()]); //两者等价
System.out.println(Arrays.toString(arr2)); // [1, 5]
// iterator迭代器
Iterator<String> it = list2.iterator();
while (it.hasNext()){
System.out.print(it.next()+" "); // 1 5
}
// 增强for循环
for(String str: list2){
System.out.print(str+ " "); // 1 5
}
}
}
!!!
Java容器——List接口的更多相关文章
- Java容器Map接口
Map接口容器存放的是key-value对,由于Map是按key索引的,因此 key 是不可重复的,但 value 允许重复. 下面简单介绍一下Map接口的实现,包括HashMap,LinkedHas ...
- Java容器List接口
List接口是Java中经常用到的接口,如果对具体的List实现类的特性不了解的话,可能会导致程序性能的下降,下面从原理上简单的介绍List的具体实现: 可以看到,List继承了Collection接 ...
- Java容器---Collection接口中的共有方法
1.Collection 接口 (1)Collection的超级接口是Iterable (2)Collection常用的子对象有:Map.List.Set.Queue. 右图中实现黑框的ArrayLi ...
- java容器——Collection接口
Collection是Set,List接口的父类接口,用于存储集合类型的数据. 2.方法 int size():返回集合的长度 void clear():清除集合里的所有元素,将集合长度变为0 Ite ...
- Java容器——Set接口
1.定义 set中不允许放入重复的元素(元素相同时只取一个).它使用equals()方法进行比较,如果返回true,两个对象的HashCode值也应该相等. 2.方法 TreeSet中常用的方法: b ...
- Java容器——Map接口
1.定义 Map用于保存存在映射关系<key, value>的数据.其中key值不能重复(使用equals()方法比较),value值可以重复. 2.常用实现类 HashMap:和Hash ...
- Java容器Set接口
Set接口的实现,可以方便地将指定的类型以集合类型保存在一个变量中.Set是一个不包含重复元素的Collection,更确切地讲,Set 不包含满足 e1.equals(e2) 的元素对,并且最多包含 ...
- Java容器深入浅出之Collection与Iterator接口
Java中用于保存对象的容器,除了数组,就是Collection和Map接口下的容器实现类了,包括用于迭代容器中对象的Iterator接口,构成了Java数据结构主体的集合体系.其中包括: 1. Co ...
- 【Java心得总结七】Java容器下——Map
我将容器类库自己平时编程及看书的感受总结成了三篇博文,前两篇分别是:[Java心得总结五]Java容器上——容器初探和[Java心得总结六]Java容器中——Collection,第一篇从宏观整体的角 ...
随机推荐
- Winfon 页签切换及窗体控件自适应
由于公司的业务调整,最近不仅开发bs,还有不熟悉的cs,人手也不足,项目还多,对于cs来说,算是小白,虽然是一个人,也是硬着头皮写,拖拽控件,自定义控件.一个项目下来,对cs有了很深的认识,这里好好感 ...
- B/S架构图解
- 【shell】awk按域去除重复行
首先解释一下什么叫“按域去除重复行”: 有的时候我们需要去除的重复行并不是整行都重复,两行的其中一列的元素相同我们有的时候就需要认定这两行重复,因此有了今天的内容. 去除重复行shell有一个原生命令 ...
- create-react-app不暴露配置设置proxy代理
此方法可以在不暴露配置的情况下直接设置代理,非常便捷 在package.json里添加 "proxy":"http://institute.dljy.lzdev" ...
- PHP7.1 mcrypt_module_open() is deprecated
PHP7.1 mcrypt_module_open() is deprecated 一:函数前添加抑制符 @ mcrypt_module_open....;->@mcrypt_module_op ...
- Spring发送邮件
Spring邮件发送流程:第一步:邮件发送,需要一个邮件服务器.可以使用腾讯获得网易的邮件服务器.登录邮箱,点击左上角的设置,再点击账号 找到下列选项,点击开启,需要发短信验证,或者使用QQ安全登录扫 ...
- bzoj 1283 序列 - 费用流
题目传送门 传送门 题目大意 给定一个长度为$n$的序列,要求选出一些数使得原序列中每$m$个连续的数中不超过$K$个被选走.问最大的可能的和. 感觉建图好妙啊.. 考虑把问题转化成选$m$次数,每次 ...
- Git 版本还原命令
转载:https://blog.csdn.net/yxlshk/article/details/79944535 1.需求场景: 在利用github实现多人协作开发项目的过程中,有时会出现错误提交的情 ...
- 复旦大学2017--2018学年第二学期高等代数II期末考试情况分析
一.期末考试成绩班级前十名 张菲诺(95).刘宇其(95).魏一鸣(93).郭宇城(92).程梓兼(91).葛珈玮(90).汪子怡(90).余张伟(90).张昰昊(89).朱柏青(89) 二.总成绩计 ...
- foreach循环里不能remove/add元素的原理
foreach循环 foreach循环(Foreach loop)是计算机编程语言中的一种控制流程语句,通常用来循环遍历数组或集合中的元素.Java语言从JDK 1.5.0开始引入forea ...