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 ...
随机推荐
- 逆向课程第二讲,寻找main入口点
逆向课程第二讲,寻找main入口点 一丶识别各个程序的入口点 入门知识,识别各个应用程序的入口点 (举例识别VC 编译器生成,以及VS编译生成的Debug版本以及Release版本) 1.识别VC6. ...
- Scrum Meeting Alpha - 8
Scrum Meeting Alpha - 8 NewTeam 2017/11/2 地点:新主楼F座二楼 任务反馈 团队成员 完成任务 计划任务 安万贺 完成了登录API的测试和包装Pull Requ ...
- 【OpenCV】通过ROI区域以及掩码实现图像叠加
在图像处理领域,我们常常需要设置感兴趣区域(ROI,region of interest),来专注或者简化我们的工作过程 .也就是从图像中选择的一个图像区域,这个区域是我们图像分析所关注的重点.我们圈 ...
- Python-psutil模块
psutil 1.简单介绍 psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等) ...
- C++静态库与动态库(转)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAA0cAAAC6CAIAAADqPKGOAAAgAElEQVR4nO2dy5WrOhREFYgjcAQ9Iw
- [转]结合HierarchyViewer和APK文件反编译获得APP元素id值
背景: 最近在使用Robotium进行Android自动化测试.遇到了一个问题:我需要获得一个View的id(int型数值).此前我在http://maider.blog.sohu.com/25544 ...
- 从.git文件夹探析git实现原理
git是一款分布式代码版本管理工具,通过git能够更加高效地协同编程.了解git的工作原理将有助于我们使用git工具更好地管理项目.通过了解.git文件夹中的文件组成,我们可以从一个角度去窥探git的 ...
- CentOS7 安装sentry(最新)
Sentry 是一款基于 Django实现的错误日志收集和聚合的平台,它是 Python 实现的,但是其日志监控功能却不局限于python,对诸如 Node.js, php,ruby, C#,ja ...
- 机器学习算法--Perceptron(感知机)算法
感知机: 假设输入空间是\(\chi\subseteq R^n\),输出空间是\(\gamma =\left( +1,-1\right)\).输入\(\chi\in X\)表示实例的特征向量,对应于输 ...
- Struts1.2,struts2.0原理分析
struts1原理: 1.首先我们表单提交到action 2.进入到web.xml 3.web.xml拦截*.do 4.交给ActionServlet 5.找到path属性,获得url 6.找到nam ...