集合体系之List及其子类ArrayList,LinkedList与Vector及其迭代器知识

List(接口)

特点:有序(存储与取出顺序相同),可重复

List子类特点:

​ ArrayList:底层结构是数组,查询快,增删慢。

​ 线程不安全,效率高。

​ Vector:底层结构是数组,查询快,增删慢。

​ 线程安全,效率低。

​ LinkedList:底层结构是链表,查询慢,增删快。

​ 线程不安全,效率高。

List特有功能

  • 添加功能

    void add(int index, E element):在指定位置添加元素
  • 获取功能

    E get(int index):返回列表中指定位置的元素。
  • 列表迭代器功能

    ListIterator<E> listIterator(int index):List特有的迭代器
  • 删除功能

    E remove(int index):移除列表中指定位置的元素,并把删除的元素返回
  • 修改功能

    E set(int index,E element):用指定元素替换列表中指定位置的元素.

List集合的特有遍历功能:

通过size()方法确定边界,在根据get()方法得到对应位置的元素

ListIterator接口

List特有的迭代器

该迭代器继承Iterator迭代器,所以,可直接用hhasNext()和next()方法

特有功能

  • hasPrevious

    boolean hasPrevious():如果以逆向遍历列表,列表迭代器有多个元素,则返回 true。
  • previous

    E previous():返回列表中的前一个元素。

    注意:只有当迭代器先正向遍历后才能逆向遍历,所以意义不大。

ArrayList (类)

特点:底层数据类型是数组,查询快,增删慢,线程不安全,效率高。

Vector (类)

特点:底层结构是数组,查询快,增删慢。线程安全,效率低。

特有功能

  • 添加功能

    • addElement
    public void addElement(E obj):将指定的组件添加到此向量的末尾,将其大小增加 1。如果向量
    的大小比容量大,则增大其容量。 被add()替代
  • 获取功能

    • elementAt
    public E elementAt(int index):返回指定索引处的组件。
    
    被get()替代
    • elements
    public Enumeration<E> elements():返回此向量的组件的枚举。
    
    被iterator()替代
Enumeration(接口 )

早期的集合迭代工具,jdk1.2后被Iterator替代

  • 方法摘要

    • hasMoreElements
    boolean hasMoreElements():测试此枚举是否包含更多的元素。
    
    被hasNext()替代
    • nextElement
    E nextElement():如果此枚举对象至少还有一个可提供的元素,则返回此枚举的下一个元素。
    
    被next()替代

LinkedList (类)

特点:底层结构是链表,查询慢,增删快。 线程不安全,效率高。

特有功能
  • 添加功能

    • addFirst
    public void addFirst(E e):将指定元素插入此列表的开头。
    • addLast
    public void addLast(E e):将指定元素添加到此列表的结尾。

  • 获取功能

    • getFirst
    public E getFirst():返回此列表的第一个元素。
    • getLast
    public E getLast():返回此列表的最后一个元素。
  • 删除功能

    • removeFirst
    public E removeFirst():移除并返回此列表的第一个元素。
    • removeLast
    public E removeLast():移除并返回此列表的最后一个元素。

Javase之集合体系(2)之List及其子类ArrayList,LinkedList与Vector及其迭代器知识的更多相关文章

  1. Javase之集合体系(4)之Map集合

    集合体系之Map集合 ##Map<K,V>( 接口 ) 特点:将键映射到值对象,一个映射不能包含重复的键:每个键只能映射一个值 Map集合与Collection集合的区别 ​ Map集合存 ...

  2. Javase之集合体系(3)之Set及其子类知识

    集合体系之Set及其子类知识 Set(接口) public interface Set<E>extends Collection<E> ​ 特点:无序(存储顺序与取出顺序不一致 ...

  3. Javase之集合体系之(1)集合顶层类Collection与其迭代器知识

    集合体系之集合顶层类Collection与其迭代器知识 集合的由来:Java是一门面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,就必须把多个对象进行存储,而要存 ...

  4. javaSE中级篇3——集合体系(另外一种存储容器)——更新完毕

    集合还是一种工具,所以它们的包都在java.util包下 1.集合的整个体系结构(是需要掌握的体系,完全体系不是这样) 对图中所说的 序和重复 这两词的说明: 序:指的是添加进去的元素和取出来的元素 ...

  5. 浅谈Java的集合体系

    集合体系框架图 集合接口 Java集合类库将接口(interface)与实现(implementation)分离,如上图,Set是一个集合接口,而HashSet与TreeSet都是实现了Set接口的子 ...

  6. JAVA提高九:集合体系

    在经过了前面的JDK6.0新特性的学习后,将进一步深入学习JDK,因为集合的重要性,因此从集合开始入手分析: 一.集合概况 Java是一种面向对象语言,如果我们要针对多个对象进行操作,那么首先必要将多 ...

  7. Java集合中List,Set以及Map等集合体系详解

    转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...

  8. Java集合体系总结

    一.集合框架 集合是容纳数据的容器,java常用的集合体系图如下.以集合中是否运行重复元素来分,主要有List和Set接口,List集合中可以有重复元素,Set集合集合中的元素不可重复,Iterato ...

  9. 大数据之路week02 Collection 集合体系收尾(Set)

    1.Set集合(理解) (1)Set集合的特点 无序,唯一. (2)HashSet集合(掌握) A: 底层数据结构是哈希表(是一个元素为链表的数组) B: 哈希表底层依赖两个方法: hashCode( ...

随机推荐

  1. SpringBoot2 整合 ClickHouse数据库,实现高性能数据查询分析

    本文源码:GitHub·点这里 || GitEE·点这里 一.ClickHouse简介 1.基础简介 Yandex开源的数据分析的数据库,名字叫做ClickHouse,适合流式或批次入库的时序数据.C ...

  2. Selenium(十七):unittest单元测试框架(三) 脚本分析、编写Web用例

    1. 带unittest的脚本分析 也许你现在心里还有疑问,unittest框架与我们前面所编写的Web自动化测试之间有什么必然联系吗?当然有,既然unittest可以组织.运行测试用例,那么为什么不 ...

  3. SSM框架之Mybatis(6)动态SQL

    Mybatis(6)动态SQL 1.动态SQL 出现原因:有些时候业务逻辑复杂时,我们的 SQL 是动态变化的,此时在前面的学习中我们的 SQL 就不能满足要求了 1.1.if标签 我们根据实体类的不 ...

  4. ArcGIS Server10.4 service发布步骤

    准备内容 安装环境:win10*64位专业版 安装文件:ArcGIS_Server_Ent_Windows_1041_150998.iso 破解文件:Lic10.4.1.ecp #安装Server前, ...

  5. xip.io

    gg gg "" "" ,gg, ,gg gg gg,gggg, gg ,ggggg, ""8b,dP" 88 I8P" ...

  6. python--django for 循环中,获取序号

    功能需求:在前端页面中,for循环id会构不成连续的顺序号,所以要找到一种伪列的方式来根据数据量定义序号 因此就用到了在前端页面中的一个字段 forloop.counter,完美解决 1 <tb ...

  7. acwing 873. 欧拉函数 模板

    地址 https://www.acwing.com/problem/content/875/ 给定n个正整数ai,请你求出每个数的欧拉函数. 欧拉函数的定义 输入格式 第一行包含整数n. 接下来n行, ...

  8. 最小化MarkdownPad 2安装体积(win10)

    一.原因 MarkdownPad2在Win10当中可能无法正常运行,右侧预览界面会出现错误"This view has crashed!"查阅官网FAQ得知大多数情况下安装Awes ...

  9. <Design> 359 346

    359. Logger Rate Limiter 用map搭建. class Logger { HashMap<String, Integer> map; /** Initialize y ...

  10. intellij idea从git检出代码并建立工程

    1. 打开intellij idea,点击configure,settings 2. 左侧展开Version Control,点击Git,点击下图中红框中按钮 3. 在弹出窗口中找到git.exe,点 ...