集合体系

一.数据结构

  1. List集合储存数据结构

    <1>堆栈结构

      特点:先进后出

      

    <2>队列结构

      特点:先进先出

    <3>数组结构

      特点:查询快,增删慢

      

    <4>链表结构

      特点:增删快,查询慢

      

二.List接口

  Java.util.List 接口(集合)extends Collection 接口

  List接口的特点:

    允许存储重复元素

    是一个有序集合(存储元素的顺序和取出元素的顺序一致)存123 取出123

    有索引,包含一些带索引的特有方法(有三种遍历方式:迭代器,增强for,普通 for)

  带索引的特有方法:

  1. add(int index, E e);在指定索引上添加元素
  2. E  remove(int index); 移除并返回指定索引处的元素
  3. E  set(index int , E e);修改并返回指定索引上的元素
  4. E  get(int index); 返回列表中指定位置的元素;

  注意:

  操作索引方法时,一定要避免索引越界异常

    IndexOutOfBoundException:索引越界异常,集合会报

      StringIndexOutOfBoundException:字符串索引越界异常

      ArrayIndexOutOfBoundException:数组索引越界异常

三.ArrayList<E>集合

  特点:

  底层是一个数组结构,查询快,增删慢;

  有序集合

  允许存储重复数据

四.Vector集合

  Jdk1.0出现,单线程,线程安全集合

五.LinkedList<E> 集合

  Java.util.LinkedList<E> 集合implements List<E>

  特点:

    底层是一个双向链表结构,查询慢,增删快;

    存取是有序的

    允许重复元素

  LinkedList特有的方法:

    增加的方法:

    1.   void addFirst(E e)  将指定元素插入到此列表的开头
    2.   void push(E e)  将元素插入此列表的开头。此方法等效于addFirst(E e)
    1.   void addList(E e) 将指定元素添加到列表的结尾,相当于add(E e);

    删除的方法:

    1.   E removeFirst();移除并返回此列表的第一个元素
    2.   E removeLast();移除返回列表的最后一个元素;
    3.   E pop()移除并返回此列表的第一个元素,此方法等效于removeFrist()

    获取的方法:

    1.   E getLast(); 获取最后一个元素
    2.   E getFrist(); 获取第一个元素
    3.   Boolean isEmpty();判断列表是否为空

六.Set集合

  Java.util.Set接口(集合) extends Collection 接口

  Set接口的特点:

    1.   不允许有重复的元素
    2.   没有索引,不能用普通for遍历

七.HashSet<E>

  Java.util.HashSet<E> 集合implements Set接口

    HashSet<E> 接口的特点

    1.   底层原理是一个哈希表(数组+单向列表),查询快,增删快
    2.   无序集合,存储的顺序有可能跟取出的顺序不一致

  使用HashSet<E> 存储元素唯一的原理:重写hashCode()方法和equals()方法;

    使用HashSet  add方法存储元素的时候,会自动调用hashCode();方法,然后对集合中的元素的哈希值进行比较,如果没有相同的哈希值,则会存入。如果哈希值有相同的,则会调用equals()方法,判断相等,如果相等不存入, 不相等存入

八.LinkedHashSet<E>

  Java.util.LinkedHashSet 集合 extends HashSet集合

  LinkedHashSet<E>特点:

    1.   底层原理:哈希表(数组+单向链表)+双向链表。
    2.   双向链表可以保证元素存取有序。但元素要求不能重复

九.哈希值

  就是一个十进制的整数,有操作系统随机给出

  可以使用Object类中的方法hashCode获取哈希值

  int hashCode()返回该对象的哈希码值;

  源码:

    Public native int hashCode();

    native:指调用了本地操作系统的方法实现

十.ArrayList<E> 集合储存不重复元素的的方法:

  1. boolean contains(Object  o); 方法判断是否包含指定元素
  2. 将ArrayList的元素遍历添加到Set 集合中
  3. 使用HashSet集合的构造方法;HashSet(Collection <? extends E> c)

java学习笔记之集合家族2的更多相关文章

  1. java学习笔记之集合家族1

    集合 集合介绍: 由于数组中存放对象,对对象操作起来不方便.java中有一类容器,专门用来存储对象. 集合与数组的区别: 1.数组的长度固定的,而集合长度时可变的 2.数组只能储存同一类型的元素,而且 ...

  2. Java学习笔记之---集合

    Java学习笔记之---集合 (一)集合框架的体系结构 (二)List(列表) (1)特性 1.List中的元素是有序并且可以重复的,成为序列 2.List可以精确的控制每个元素的插入位置,并且可以删 ...

  3. Java学习笔记之集合

    集合(Collection)(掌握) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组而数组的长度固定 ...

  4. 【原】Java学习笔记026 - 集合

    package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:从三国演义中 ...

  5. 【Java学习笔记】集合转数组---toArray()

    package p2; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class ...

  6. 【Java学习笔记】<集合框架>定义功能去除ArrayList中的重复元素

    import java.util.ArrayList; import java.util.Iterator; import cn.itcast.p1.bean.Person; public class ...

  7. 【原】Java学习笔记028 - 集合

    package cn.temptation; import java.util.HashSet; import java.util.Set; public class Sample01 { publi ...

  8. 5.3类集(java学习笔记)集合的输出

    一.集合的输出 迭代输出:Iteratror接口 在输出集合时,最标准的方法是使用迭代器迭代输出. 1,List中的迭代器. Iterator中包含三个方法: hasNex()t判断集合内是否有元素存 ...

  9. java学习笔记——Collection集合接口

    NO 方法名称 描述 1 public boolean add(E e) 向集合中保存数据 2 public void clear() 清空集合 3 public boolean contains(O ...

随机推荐

  1. css设置黑体宋体等(转)

    代码如下: .selector{ font-family:"Microsoft YaHei",微软雅黑,"MicrosoftJhengHei",华文细黑,STH ...

  2. eclipse禁用svg文件Validation

    1.打开window>preferences>validation找到xml validator 2.点击xml validator最右侧的按钮打开xml校验规则窗口,选中exclude ...

  3. sass学习--安装ruby

    1.下载ruby:https://rubyinstaller.org/downloads/ 2.安装完ruby之后,在开始菜单中,找到刚才我们安装的ruby,打开Start Command Promp ...

  4. vue初级学习--idea的环境搭建

    一.导语 最近接触了下idea,虽然我对于各种"代码界的神器"没有多大感冒,一个eclipse或者myeclipse,一个Notepad++ .一个就可以把我征服,但还是蛮喜欢id ...

  5. Vue js 的生命周期详解

    Vue 实例的生命周期 Vue 实例有一个完整的生命周期,也就是从开始创建.初始化数据.编译模板.挂载Dom→渲染.更新→渲染.卸载等一系列 过程,我们称这是 Vue 的生命周期.通俗说就是 Vue ...

  6. 第一章 Linux系统介绍与环境搭建准备

    1.操作系统: Operating System,简称OS,它是应用程序运行以及用户操作必备的基础环境支撑,是计算机系统的核心. 操作系统就是处于用户与计算机系统硬件之间用于传递信息的系统程序软件. ...

  7. 分享:苹果APP更新上架被拒的另一种理由(Safety - Objectionable Content)

    这两个星期,本来想和大伙分享:写IT连创业系列运营篇. 但时间飞过,仍只是写了开头,一直很忙,没能完往下写. 今天就动手写点其它内容,哈哈,免的和小伙伴太陌生〜〜〜 前几天更新了:IT恋和IT连的版本 ...

  8. vim如何显示行号

    在 vim 里执行(在普通模式下直接按冒号,并输入下面的命令 :set number 回车后就可以显示行号了,但重启 vim 后又会恢复默认的设置. 要想每次进入 vim 都显示行号就需要配置 vim ...

  9. linux操作系统基础篇(三)

    1.cat命令 cat除了可以用来查看文本文档还可以将两个文本文档纵向合并到另外一个文本文档中 比如 cat /etc/passwd /etc/group > 1.txt 2. 归纳了所有的压缩 ...

  10. iBatis.net技术实践

    随着大数据技术的兴起和快速发展,人们更多的开始关注HDFS.HBase.Hive等技术.但是谈到强一致性,我们又不得不回归现实,只能继续沿用RDBMS存储强一致性的数据.我们日常接触到的绝大多数的应用 ...