Javase之集合体系(2)之List及其子类ArrayList,LinkedList与Vector及其迭代器知识
集合体系之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及其迭代器知识的更多相关文章
- Javase之集合体系(4)之Map集合
集合体系之Map集合 ##Map<K,V>( 接口 ) 特点:将键映射到值对象,一个映射不能包含重复的键:每个键只能映射一个值 Map集合与Collection集合的区别 Map集合存 ...
- Javase之集合体系(3)之Set及其子类知识
集合体系之Set及其子类知识 Set(接口) public interface Set<E>extends Collection<E> 特点:无序(存储顺序与取出顺序不一致 ...
- Javase之集合体系之(1)集合顶层类Collection与其迭代器知识
集合体系之集合顶层类Collection与其迭代器知识 集合的由来:Java是一门面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,就必须把多个对象进行存储,而要存 ...
- javaSE中级篇3——集合体系(另外一种存储容器)——更新完毕
集合还是一种工具,所以它们的包都在java.util包下 1.集合的整个体系结构(是需要掌握的体系,完全体系不是这样) 对图中所说的 序和重复 这两词的说明: 序:指的是添加进去的元素和取出来的元素 ...
- 浅谈Java的集合体系
集合体系框架图 集合接口 Java集合类库将接口(interface)与实现(implementation)分离,如上图,Set是一个集合接口,而HashSet与TreeSet都是实现了Set接口的子 ...
- JAVA提高九:集合体系
在经过了前面的JDK6.0新特性的学习后,将进一步深入学习JDK,因为集合的重要性,因此从集合开始入手分析: 一.集合概况 Java是一种面向对象语言,如果我们要针对多个对象进行操作,那么首先必要将多 ...
- Java集合中List,Set以及Map等集合体系详解
转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...
- Java集合体系总结
一.集合框架 集合是容纳数据的容器,java常用的集合体系图如下.以集合中是否运行重复元素来分,主要有List和Set接口,List集合中可以有重复元素,Set集合集合中的元素不可重复,Iterato ...
- 大数据之路week02 Collection 集合体系收尾(Set)
1.Set集合(理解) (1)Set集合的特点 无序,唯一. (2)HashSet集合(掌握) A: 底层数据结构是哈希表(是一个元素为链表的数组) B: 哈希表底层依赖两个方法: hashCode( ...
随机推荐
- SpringBoot2.0 基础案例(17):自定义启动页,项目打包和指定运行环境
本文源码 GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.打包简介 springboot的打包方式有很多种.可以打war ...
- Asp .Net Core Excel导入和导出
ASP .Net Core使用EPPlus实现Api导入导出,这里使用是EPPlus 4.5.2.1版本,.Net Core 2.2.在linux上运行的时候需要安装libgdiplus . 下面我们 ...
- 基于STM32F429,Cubemx的SAI音频播放实验
书接上文:https://www.cnblogs.com/feiniaoliangtiangao/p/11060674.html 和 https://www.cnblogs.com/feiniaoli ...
- 应届生offer指南
通用技术 1.一般公司对应届生都要考察编程能力,所以应聘之前先刷刷题.我做面试官出的编程题两年没有变过.就是这道
- JavaScript中的this绑定丢失及解决方法
经常犯的错误:混淆了this绑定规则. 代码如下: var obj = { id: 'vexekefo', cool() { console.log(this.id); } }; var id = ' ...
- mysql登陆时出现ERROR 2013 (HY000): Lost connection to MySQL server at 'reading initial communication packet', system error: 0
有4到5天没开mysql,这天晚上打=打开phpstudy,想进去mysql练习练习,结果丢给我这个 ERROR 2013 (HY000): Lost connection to MySQL serv ...
- Cesium专栏-克里金插值(全国温度为例,附源码下载)
Cesium Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精 ...
- GO 全面解析 json tag 篇
在处理json格式字符串的时候,经常会看到声明struct结构的时候,属性的右侧还有反引号括起来的内容.形如: type User struct { UserId int `json:"us ...
- 一文解读HTTP2 (转)
作为一个经常和web打交道的程序员,了解这些协议是必须的,本文就向大家介绍一下这些协议的区别和基本概念,文中可能不局限于前端知识,还包括一些运维,协议方面的知识,希望能给读者带来一些收获,如有不对之处 ...
- 中缀表达式转换为后缀表达式(python实现)
中缀表示式转换为后缀表达式 需要一个存放操作符的栈op_stack,输出结果的列表output 步骤: 从左到右遍历表达式: 1. 若是数字,直接加入到output 2. 若是操作符,比较该操作符和o ...