序章 

 List集合是一个元素有序且可以重复的集合,每个元素对应一个索引,类似于数组的方式,默认是按照添加顺序,所以第一次添加元素索引为0,第二次为1。。。。

一 Java8改进的List接口和ListIterator接口

  List作为Collection接口的子接口,可以使用Collection接口的所有方法,同时由于为有序集合,所以增加了一些根据索引来操作集合元素的方法。

  新增方法如下:

  void add(int index,Object element):将元素element插入到List集合的index处。

  boolean addAll(int index,Collection c):将集合c所包含的所有元素插入到List集合的index处。

Object get(int index):返回集合index索引处的元素。

  int indexOf(Object o):返回对象o在List集合中第一次出现的位置信息。

  int  lastIndexOf(Object o):返回对象o在List集合中最后一次出现的位置索引。

  Object remove(int index):删除并返回index索引处的元素。

  Object set(int index,Object element):将index索引处的元素替换成element对象,返回被替换的旧元素。

  List subList(int fromIndex,int toIndex):返回从索引fromIndex(包含)到toIndex(不包含)处所有集合元素组成的子集合。

    所有List实现类都可以调用这些方法来操作集合元素。相比Set,List增加了根据索引来插入,替换和删除集合元素的方 法。除此之外,Java8还增加了如下两个默认方法

  void replaceAll(UnaryOperator operator):根据operator指定的计算规则重新设置List集合的所有元素。

  void sort(Comparatorc):根据Comparator参数对List集合的元素排序。

  代码示例

package com.j1803.listTest;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
public class ListTest {
public static void main(String[] args) {
List book=new ArrayList();
Set set=new HashSet();
set.add(78);
set.add(new String("DDDD"));
set.add("EEEE");
set.add("BBBB");
book.add(new String("AAAA"));
book.add(new String("BBBB"));
book.add(new String("CCCC"));
//book.add(5,new String("DDDD"));报错java.lang.IndexOutOfBoundsException: Index: 5, Size: 3
book.add(3,new String("DDDD"));
System.out.println(book);
book.addAll(set);
System.out.println(book);
System.out.println(book.get(2));
System.out.println(book.indexOf("CCCC"));
System.out.println(book.indexOf("BBBB"));
System.out.println(book.lastIndexOf("BBBB"));
System.out.println(book.remove("BBBB"));
System.out.println(book);
System.out.println(book.remove(1));
System.out.println(book);
book.set(0, new String("Hello World"));
System.out.println(book);
System.out.println(book.subList(0, 3));
} }
[AAAA, BBBB, CCCC, DDDD]
[AAAA, BBBB, CCCC, DDDD, EEEE, 78, DDDD, BBBB]
CCCC
2
1
7
true
[AAAA, CCCC, DDDD, EEEE, 78, DDDD, BBBB]
CCCC
[AAAA, DDDD, EEEE, 78, DDDD, BBBB]
[Hello World, DDDD, EEEE, 78, DDDD, BBBB]
[Hello World, DDDD, EEEE]

    List通过equals方法来判断两个对象是否相等。如果equals返回为true则相等,否则则不想等。

  代码示例

package com.j1803.listTest;
import java.util.ArrayList;
import java.util.List;
public class ListTest2 {
public static void main(String[] args) {
List list=new ArrayList();
list.add("AA");
list.add("BB");
list.add("CC");
System.out.println(list);
list.remove(new A());
System.out.println(list);
list.remove(new A());
System.out.println(list);
}
}
class A{
public boolean equals(Object obj) {
return true;
}
}
[AA, BB, CC]
[BB, CC]
[CC]

  

  

  

java集合(5)-List集合的更多相关文章

  1. Java常用的几种集合, Map集合,Set集合,List集合

    Java中  Object是所有类的根 Java集合常用的集合List集合.Set集合.Map集合 Map接口常用的一些方法 size() 获取集合中名值对的数量 put(key k, value v ...

  2. Java基础加强之集合篇(模块记忆、精要分析)

    千里之行,始于足下.把别人的变成自己,再把自己的分享给别人,这也是一次提升的过程.本文的目的是以一篇文章从整体把握集合体系又不失一些细节上的实现,高手路过. 集合的作用与特点 Java是一门面向对象语 ...

  3. Java中如何克隆集合——ArrayList和HashSet深拷贝

    编程人员经常误用各个集合类提供的拷贝构造函数作为克隆List,Set,ArrayList,HashSet或者其他集合实现的方法.需要记住的是,Java集合的拷贝构造函数只提供浅拷贝而不是深拷贝,这意味 ...

  4. Java多线程系列--“JUC集合”02之 CopyOnWriteArrayList

    概要 本章是"JUC系列"的CopyOnWriteArrayList篇.接下来,会先对CopyOnWriteArrayList进行基本介绍,然后再说明它的原理,接着通过代码去分析, ...

  5. Java多线程系列--“JUC集合”03之 CopyOnWriteArraySet

    概要 本章是JUC系列中的CopyOnWriteArraySet篇.接下来,会先对CopyOnWriteArraySet进行基本介绍,然后再说明它的原理,接着通过代码去分析,最后通过示例更进一步的了解 ...

  6. Java多线程系列--“JUC集合”04之 ConcurrentHashMap

    概要 本章是JUC系列的ConcurrentHashMap篇.内容包括:ConcurrentHashMap介绍ConcurrentHashMap原理和数据结构ConcurrentHashMap函数列表 ...

  7. Java多线程系列--“JUC集合”05之 ConcurrentSkipListMap

    概要 本章对Java.util.concurrent包中的ConcurrentSkipListMap类进行详细的介绍.内容包括:ConcurrentSkipListMap介绍ConcurrentSki ...

  8. Java多线程系列--“JUC集合”06之 ConcurrentSkipListSet

    概要 本章对Java.util.concurrent包中的ConcurrentSkipListSet类进行详细的介绍.内容包括:ConcurrentSkipListSet介绍ConcurrentSki ...

  9. Java多线程系列--“JUC集合”07之 ArrayBlockingQueue

    概要 本章对Java.util.concurrent包中的ArrayBlockingQueue类进行详细的介绍.内容包括:ArrayBlockingQueue介绍ArrayBlockingQueue原 ...

  10. Java多线程系列--“JUC集合”08之 LinkedBlockingQueue

    概要 本章介绍JUC包中的LinkedBlockingQueue.内容包括:LinkedBlockingQueue介绍LinkedBlockingQueue原理和数据结构LinkedBlockingQ ...

随机推荐

  1. 什么是 Web 服务器(server)

    首先我们来了解什么是服务器(server) Web服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,可以向浏览器等Web客户端提供文档,[1]也可以放置网站文件,让全世界浏览:可以放置数 ...

  2. Mobileye 自动驾驶策略(一)

    Mobileye 自动驾驶策略(一) 详解 Mobileye 自动驾驶解决方案 Mobileye的自动驾驶解决方案.总得来说,分为四种: Visual perception and sensor fu ...

  3. JVM面试题(史上最强、持续更新、吐血推荐)

    文章很长而且持续更新,建议收藏起来,慢慢读! 高并发 发烧友社群:疯狂创客圈(总入口) 奉上以下珍贵的学习资源: 疯狂创客圈 经典图书 : 极致经典 + 社群大片好评 < Java 高并发 三部 ...

  4. Spring Boot WebFlux-导读

    背景 大家都知道,Spring Framework 是 Java/Spring 应用程序跨平台开发框架,也是 Java EE(Java Enterprise Edition) 轻量级框架,其 Spri ...

  5. 超赞!IDEA 最新版本,支持免打扰和轻量模式!

    IntelliJ IDEA 2020.1 的第二个早期访问版本已发布,新的 EAP 构建对调试器和事件探查器(Profiler)进行了改进,并引入了新的提交工具窗口(Commit toolwindow ...

  6. MindSpore自定义模型损失函数

    技术背景 损失函数是机器学习中直接决定训练结果好坏的一个模块,该函数用于定义计算出来的结果或者是神经网络给出的推测结论与正确结果的偏差程度,偏差的越多,就表明对应的参数越差.而损失函数的另一个重要性在 ...

  7. 【模拟8.09】建设城市(city) (容斥)

    放在了考试T1 发现70分的DP很水啊,f[i][j]为当前位置是i分配了j个队的方案 我们用前缀和统计,在将i删去,j倒序枚举,就可以删掉一维(也可以滚动数组滚起来) 1 #include<i ...

  8. 如何编写shell脚本

    1.首先创建一个目录 vi hello.sh 2.编写shell第一行 #!/bin/bash    (为了声明是shell脚本,第一行都要这么写) 3.可以添加注释     #the first p ...

  9. MaterialDesignInXamlToolkit“无法绑定到目标方法,因其签名或安全透明度与委托类型的签名或安全透明度不兼容”异常的解决思路

    前言: 最初是想解答园友"小代码大世界 "的问题,后来想举一反三,将这个问题简单剖析下,做到知其所以然. MaterialDesignInXAML 控件库高度封装,有一些控件在使用 ...

  10. Kubernetes的资源管理

    本节讲解为一个pod配置资源的预期使用量和最大使用量.通过设置这两组参数,可以确保pod公平地使用Kubernetes集群资源,同时也影响着整个集群pod的调度方式. 1.为pod中的容器申请资源 创 ...