java学习笔记之集合家族2
集合体系
一.数据结构
- List集合储存数据结构
<1>堆栈结构
特点:先进后出

<2>队列结构
特点:先进先出
<3>数组结构
特点:查询快,增删慢

<4>链表结构
特点:增删快,查询慢

二.List接口
Java.util.List 接口(集合)extends Collection 接口
List接口的特点:
允许存储重复元素
是一个有序集合(存储元素的顺序和取出元素的顺序一致)存123 取出123
有索引,包含一些带索引的特有方法(有三种遍历方式:迭代器,增强for,普通 for)
带索引的特有方法:
- add(int index, E e);在指定索引上添加元素
- E remove(int index); 移除并返回指定索引处的元素
- E set(index int , E e);修改并返回指定索引上的元素
- E get(int index); 返回列表中指定位置的元素;
注意:
操作索引方法时,一定要避免索引越界异常
IndexOutOfBoundException:索引越界异常,集合会报
StringIndexOutOfBoundException:字符串索引越界异常
ArrayIndexOutOfBoundException:数组索引越界异常
三.ArrayList<E>集合
特点:
底层是一个数组结构,查询快,增删慢;
有序集合
允许存储重复数据
四.Vector集合
Jdk1.0出现,单线程,线程安全集合
五.LinkedList<E> 集合
Java.util.LinkedList<E> 集合implements List<E>
特点:
底层是一个双向链表结构,查询慢,增删快;
存取是有序的
允许重复元素
LinkedList特有的方法:
增加的方法:
- void addFirst(E e) 将指定元素插入到此列表的开头
- void push(E e) 将元素插入此列表的开头。此方法等效于addFirst(E e)
- void addList(E e) 将指定元素添加到列表的结尾,相当于add(E e);
删除的方法:
- E removeFirst();移除并返回此列表的第一个元素
- E removeLast();移除返回列表的最后一个元素;
- E pop()移除并返回此列表的第一个元素,此方法等效于removeFrist()
获取的方法:
- E getLast(); 获取最后一个元素
- E getFrist(); 获取第一个元素
- Boolean isEmpty();判断列表是否为空
六.Set集合
Java.util.Set接口(集合) extends Collection 接口
Set接口的特点:
- 不允许有重复的元素
- 没有索引,不能用普通for遍历
七.HashSet<E>
Java.util.HashSet<E> 集合implements Set接口
HashSet<E> 接口的特点
- 底层原理是一个哈希表(数组+单向列表),查询快,增删快
- 无序集合,存储的顺序有可能跟取出的顺序不一致
使用HashSet<E> 存储元素唯一的原理:重写hashCode()方法和equals()方法;
使用HashSet add方法存储元素的时候,会自动调用hashCode();方法,然后对集合中的元素的哈希值进行比较,如果没有相同的哈希值,则会存入。如果哈希值有相同的,则会调用equals()方法,判断相等,如果相等不存入, 不相等存入
八.LinkedHashSet<E>
Java.util.LinkedHashSet 集合 extends HashSet集合
LinkedHashSet<E>特点:
- 底层原理:哈希表(数组+单向链表)+双向链表。
- 双向链表可以保证元素存取有序。但元素要求不能重复
九.哈希值
就是一个十进制的整数,有操作系统随机给出
可以使用Object类中的方法hashCode获取哈希值
int hashCode()返回该对象的哈希码值;
源码:
Public native int hashCode();
native:指调用了本地操作系统的方法实现
十.ArrayList<E> 集合储存不重复元素的的方法:
- boolean contains(Object o); 方法判断是否包含指定元素
- 将ArrayList的元素遍历添加到Set 集合中
- 使用HashSet集合的构造方法;HashSet(Collection <? extends E> c)
java学习笔记之集合家族2的更多相关文章
- java学习笔记之集合家族1
集合 集合介绍: 由于数组中存放对象,对对象操作起来不方便.java中有一类容器,专门用来存储对象. 集合与数组的区别: 1.数组的长度固定的,而集合长度时可变的 2.数组只能储存同一类型的元素,而且 ...
- Java学习笔记之---集合
Java学习笔记之---集合 (一)集合框架的体系结构 (二)List(列表) (1)特性 1.List中的元素是有序并且可以重复的,成为序列 2.List可以精确的控制每个元素的插入位置,并且可以删 ...
- Java学习笔记之集合
集合(Collection)(掌握) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组而数组的长度固定 ...
- 【原】Java学习笔记026 - 集合
package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:从三国演义中 ...
- 【Java学习笔记】集合转数组---toArray()
package p2; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class ...
- 【Java学习笔记】<集合框架>定义功能去除ArrayList中的重复元素
import java.util.ArrayList; import java.util.Iterator; import cn.itcast.p1.bean.Person; public class ...
- 【原】Java学习笔记028 - 集合
package cn.temptation; import java.util.HashSet; import java.util.Set; public class Sample01 { publi ...
- 5.3类集(java学习笔记)集合的输出
一.集合的输出 迭代输出:Iteratror接口 在输出集合时,最标准的方法是使用迭代器迭代输出. 1,List中的迭代器. Iterator中包含三个方法: hasNex()t判断集合内是否有元素存 ...
- java学习笔记——Collection集合接口
NO 方法名称 描述 1 public boolean add(E e) 向集合中保存数据 2 public void clear() 清空集合 3 public boolean contains(O ...
随机推荐
- Cactus
Cactus Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- 使用Identity Server 4建立Authorization Server (2)
第一部分: http://www.cnblogs.com/cgzl/p/7780559.html 第一部分主要是建立了一个简单的Identity Server. 接下来继续: 建立Web Api项目 ...
- cookie在不同域名domain、path下的读取规则
cookie 子域名可以读父域名中的cookie 如在 .ping.com域下注入cookie,则该子域下的网页如p1.ping.com.p2.ping.com 都能读取到cookie信息 path的 ...
- aria-label
元素中的 aria-label用来命名一个元素 它的值可以是任何字符 读屏软件就会读出aria-label里的内容 <div role=”form” aria-labelledby= ...
- web前端学习路线和步骤
H5+全栈工程师 (学习下列技术可以加QQ: 1416 7596 61)第一阶段:初级入门阶段基本功 1.HTML入门 Windows概述.浏览器概述.HTML简介.HTML标签详解.前端开发工具概 ...
- 开源API测试工具 Hitchhiker v0.4更新 - 没有做不到,只有想不到
Hitchhiker 是一款开源的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起管理Api. 详细介绍 ...
- Javascript实现简单跨域调用
什么是JSONP? 1.一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面.动态网页.web服务.WCF,只要是跨域请求,一律不准: 2.不过我们又发现,Web页面 ...
- 洛谷 P3391 【模板】文艺平衡树
题目背景 这是一道经典的Splay模板题--文艺平衡树. 题目描述 您需要写一种数据结构,来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4 ...
- 软件测试博客日记Day02-11.16日 —— 赵天宇 —— 禅道的使用和配置
禅道 1. 安装 1. 进入禅道的官方下载地址:http://www.zentao.net/download/80053.html 2. 下载禅道开源版本. 3. 正常安装,注意一定要放在根目录下. ...
- ArrayList迭代过程删除问题
一:首先看下几个ArrayList循环过程删除元素的方法(一下内容均基于jdk7): package list; import java.util.ArrayList; import java.uti ...