一.List接口的继承关系

List接口是Collection接口的子接口,而ArrayList和LinkedList以及Vector是其实现类。

List的特点是可以将元素维护在特定的序列中,可以再List 插入和删除元素。

二.两个实现类ArrayList和LinkedList

ArrayList:擅长随机访问,但是插入和删除消耗较慢,原因:底层维护的是一个Object数组

源码如下:

    /**
* The array buffer into which the elements of the ArrayList are stored.
* The capacity of the ArrayList is the length of this array buffer. Any
* empty ArrayList with elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
* will be expanded to DEFAULT_CAPACITY when the first element is added.
*/
transient Object[] elementData; // non-private to simplify nested class access

LinkedList:擅长插入,删除。但是不擅长随机访问,原因底层是一个链表

头结点的代码:

   /**
* Links e as first element.
*/
private void linkFirst(E e) {
final Node<E> f = first;
final Node<E> newNode = new Node<>(null, e, f);
first = newNode;
if (f == null)
last = newNode;
else
f.prev = newNode;
size++;
modCount++;
}

三.List接口实现的常用方法

首先在了解List之前先来了解ArrayList和LinkedList的构造函数

通常情况下我们都是直接不像构造器里传参数,那么此时他们的默认长度为10,此后每一次扩容为1.5倍,即每次加5.

当你初始化时传入一个数字,那么它将设置该数值为初始长度,代码如下:

ArrayList<Node> arr1 = new ArrayList<>(1);//指派出的长度,当不满足是在自动分配

当然你也可以通过Arrays.asList方法来传入List对象来实现,代码如下:

List<Node> arr = new ArrayList<>(Arrays.asList(new Node(),new Node()));//可以在初始化时就创建

以下为List实现的方法:

1.add()————增加方法。

arr1.add(new Node(1,"a"));//添加元素
arr1.add(new Node(2,"b"));//添加元素
arr1.add(new Node(1,"a"));//添加一个相同重复的元素

2.get()————获取元素。

System.out.println(arr1.get(0));

3.remove————移除一个元素的方法(equals匹配)

System.out.println(arr1.remove(new Node(1,"a")));//true  Node类重写了equals方法所以可以被删除,且删除第一个遇到匹配的

4.removeAll————移除所有匹配相同的元素方法(equals匹配)

arr4.removeAll(Arrays.asList(new Node()));//使用equals来判断删除所有的

5.indexOf————返回匹配元素在集合中的第一次相遇的元素位置(equals匹配),没有匹配到时将返回-1

System.out.println(arr1.indexOf(new Node(1,"a")));//返回在arr中的序列没有返回-1

6.addAll————将collection接口实现的子类对象加入到集合中,这也就是说你可以将Set集合和Queue中的元素加入到List集合中

//在ArrayList中插入Set集合
Set<Node> set=new HashSet<>();
Collections.addAll(set, new Node(3,"c"),new Node(4,"d"));//初始化set集合
arr1.addAll(set);

7.subList————分割出子集合,返回类型为List,注意当使用List的实现类来操作是注意向下转型异常。

//获取子集合,使用linkedList  subList返回的类型为List,不能直接使用,不能实现向下转型,使用多态解决
List<Node> arr2=new LinkedList<>();
arr2=arr1.subList(0, 2);//subList返回类型为List 向下转型会出现异常,只有使用多态才能完成操作
System.out.println(arr2);
//获取子集和使用arrayList
List<Node> arr3= arr1.subList(0, 2);

 8.————排序问题和引用问题

List<Node> arr3= arr1.subList(0, 2);
System.out.println("在没有排序之前子串str3为:");
System.out.println(arr3);
Collections.sort(arr3);
System.out.println("在排序之后子串str3为:");
System.out.println(arr3);
System.out.println(arr1);//子串排序后其母串也排序

首先想要实现sort方法,元素类必须实现comparable接口

发现当我们,子集完成排序后母集中子集部分也完成排序。

原因就是我们的subList()只是在堆里直接引用了母集的部分元素,他们指向的对象还是相同的,所以当你对子集做出改变时母集也会改变。

Java中的容器 I————浅谈List的更多相关文章

  1. Java中的容器 I————浅谈Queue和PriorityQueue

    一.Queue的实现 通过LinkedList类实现Queue接口来完成对Queue的实例类的实现,代码如下: Queue<Integer> queue=new LinkedList< ...

  2. 对kotlin和java中的synchronized的浅谈

    synchronized在java中是一个关键字,但是在kotlin中是一个内联函数.假如分别在java和kotlin代码锁住同一个对象,会发生什么呢,今天写了代码试了试.首先定义people类 12 ...

  3. Java中Integer和String浅谈

    Java中的基本数据类型有八种:int.char.boolean.byte.long.double.float.short.Java作为一种面向对象的编程语言,数据在Java中也是一种对象.我们用基本 ...

  4. Java中常用修饰符浅谈

    一.public.protected.default和private修饰符的作用域 public:在java程序中,如果将属性和方法定义为 public 类型,那么此属性和方法所在的类和及其子类,同一 ...

  5. Java中的SPI原理浅谈

    在面向对象的程序设计中,模块之间交互采用接口编程,通常情况下调用方不需要知道被调用方的内部实现细节,因为一旦涉及到了具体实现,如果需要换一种实现就需要修改代码,这违反了程序设计的"开闭原则& ...

  6. .net中对象序列化技术浅谈

    .net中对象序列化技术浅谈 2009-03-11 阅读2756评论2 序列化是将对象状态转换为可保持或传输的格式的过程.与序列化相对的是反序列化,它将流转换为对象.这两个过程结合起来,可以轻松地存储 ...

  7. java中的容器问题

    小小的总结一下java中的容器问题. 一.三个知识点 1.迭代器 1).java.util.Interator + hasnext(); next(); remove(); 2).java.lang. ...

  8. Java中的容器(集合)之ArrayList源码解析

    1.ArrayList源码解析 源码解析: 如下源码来自JDK8(如需查看ArrayList扩容源码解析请跳转至<Java中的容器(集合)>第十条):. package java.util ...

  9. Java中的容器(集合)之HashMap源码解析

    1.HashMap源码解析(JDK8) 基础原理: 对比上一篇<Java中的容器(集合)之ArrayList源码解析>而言,本篇只解析HashMap常用的核心方法的源码. HashMap是 ...

随机推荐

  1. 二、持久层框架(Hibernate)

    一.Hibernate对象的状态 实体类对象在Hibernate中有3中状态:瞬时,持久,脱管. 瞬时:没有和Hibernate发生任何关系,在数据库中也没有对应的记录,一旦JVM结束,对象就消失了 ...

  2. jQuery-全屏滚动插件【fullPage.js】API 使用方法总结

    jQuery-全屏滚动插件[fullPage.js]API 使用方法总结   jQuery-全屏滚动插件fullPage.js使用方法总结 作者github及下载地址:https://github.c ...

  3. iOS block 机制

    本文要将block的以下机制,并配合具体代码详细描述: block 与 外部变量 block 的存储域:栈块.堆块.全局块 定义 块与函数类似,只不过是直接定义在另一个函数里,和定义它的那个函数共享同 ...

  4. ReactiveCocoa入门教程--第二部分

    翻译自:http://www.raywenderlich.com/62796/reactivecocoa-tutorial-pt2 ReactiveCocoa 是一个框架,它允许你在你的iOS程序中使 ...

  5. Express 路径请求及对应的获取路径形式

    req.query // GET /search?q=tobi+ferret req.query.q // => "tobi ferret" // GET /shoes?or ...

  6. qq远程连接/windows远程桌面/teamviwer/xmanager/vnc的区别

    软件 客户端运行平台 服务端运行平台 服务端是否需要同子网或公网IP 网络断开当前执行命令是否会中止 评价 QQ远程连接 windows windows 否 否 感觉用了一两分钟就动不了了 windo ...

  7. java基础语法运算符

    1.1                算数运算符++.--的使用 在一般情况下,算数运算符不会改变参与计算的变量值.而是在原有变量值不变的情况下,计算出新的值.但是有些操作符会改变参与计算的变量的值, ...

  8. ID基本操作(创建主页,复制主页,把主页应用到多个页面)5.11

    主页上的对象将会显示在应用在这个主页上的所有页面. 一.创建主页的方法: 1.页面面板,右上方点击,可以新建主页..前缀:用来识别页面面板中的各个页面所应用的主页.最多可输入四个字符.名称:输入主页跨 ...

  9. laravel处理菜单保持的方法:

    <!-- 左侧菜单区域 --> <div class="col-md-3"> @section('leftmenu') <div class=&quo ...

  10. weblogic相关

    来源:http://zhidao.baidu.com/link?url=gqPaYovGiEHYPPPyI6PgPV6THVLr4nlj3CGCjY3mwm0-ERUnfuQz614ywAwYLnP6 ...