背景:

看的是《java核心技术 第8版》,覆盖jdk1.6。主要是对集合全局和细节进行全面掌握,较深入的理解集合。本人对java比较熟悉,但是对于细节的理解不深,知识点还不全,这是知识的查缺不漏。

一.集合接口

  1. 接口和实现分离

当程序中使用集合时,一旦构建了集合就不需要知道究竟使用的哪种实现,因此,只有构建集合对象时,使用具体的类才有意义。可以使用接口类型存放集合的引用。

2.  集合接口和迭代接口

java迭代器应该认为是位于两个元素中间,当调用next时,迭代器就越过下一个元素。

Iterator接口的remove方法会删除上次调用next方法时返回的元素。重要的是,对next方法和remove方法的调用具有互相依赖性。

为了能够让实现者更容易得实现这个接口,java类库提供了一个类AbstractCollection。

二.具体的集合

1.链表 linkedlist

Linkedlist和Arraylist区别:从实现上,al采用的是数组,可以高效地随机访问;而ll采用的是内部了entry,这个类里有对象还有节点的前后指针,因此不能随机访问,只能从头遍历,但是插入,删除简单,不需要移动前后数据。

Linkedlist.add方法将对象添加到链表的尾部;而经常需要在链表的中间插入元素,而接口Iterator中没有add方法,集合类提供了子接口Listiterator,它里面提供了add方法,除此之外,还提供了方向遍历的方法:previous,hasPrevious方法。

2.数组列表 arraylist

如果使用动态数组,经验丰富的人,一般会选择vector,但是为什么会用arraylist替换vector呢?vector是线程同步的,arraylist线程不同步,但是如果单线程访问时,用arraylist性能开销比较小。

3.散列集

在java中,散列表的实现通过HashSet类。散列表是通过链表数组实现的,每个链表称为桶(bucket)。这里面桶的数量设置通常是元素个数的75%-150%;还有装填因子load factor,决定何时对散列表进行再散列,在散列时用双倍的桶数自动地进行再散列。

4.树集

特点-有序集。以任意顺序插入到集合,在对集合进行遍历时,每个值将自动地按照排序后的顺序呈现。

采用的是红黑树(red-black-tree)。

在TreeSet中,元素是如何进行比较的?默认情况,树集假定插入的元素实现了Comparable接口,这个接口定义了compareTo方法。但是Comparable接口,尤其明显的局限性,局限性体现在:在给定的类中,只能实现一次接口;如果一个集合是按照a属性排序,在另一个集合按照b属性排序,该怎么办?另外,如果需要对一个类的对象进行排序,而这个类的创建者又没有实现Comparable接口,该如何办?

在java中对这种情况,提出了Comparator对象传递给TreeSet构造器来告诉树集使用不同的对比比较方法。

到底是否需要用树集取代散列集呢?这取决于所要收集的数据,对其排序要比散列函数要困难时,用树集比较合适。没有排序要求时,用散列集比较合适。

5.队列与双端队列

队列是在尾部插入元素,在头部删除元素;不支持在队列中间插入元素

双端队列,是同时在头部和尾部插入或删除元素。

java se6中引入了Deque接口,并由ArrayDeque和LinkedList类实现。

6.优先级队列 Priority queue

优先级队列可以按照任意的顺序插入,却总是按照排序的顺序进行检索。也就是说,无论何时调用remove方法,总会获得当前优化级队列中最小的元素。

使用优先级队列最典型的场景就是任务调度。

7.映射表

映射表(map),java类库中提供了2个通用实现:HashMap和TreeMap,这2个实现了Map接口。

是选择散列映射表还是树映射表?与之前的集一样,散列稍微快一些,如果不需要按照排序顺序访问键,那就最好选择散列。

映射表可以获得它的视图,这是实现了Collection接口的对象或是它的子接口的视图。这3个视图分别是键集,值集合,和键/值对集。

8.专用集与l映射表类

  • WeakHashMap
  • 链接散列集和链接映射表

用来记住插入元素项顺序,这样就可以避免在散列表中的项从表面上看是随机排列的。链接散列映射表LinkedHashMap将用访问顺序,而不是插入顺序,对映射表条目进行迭代。

  • 枚举集与枚举映射表
  • 标识哈希映射表IdentityHashMap,键的散列值是用System.identityHashCode方法计算的。此类在实现对象遍历算法时(如对象序列化),非常有用。

三.集合框架

  1. 视图与包装器

哈希表类的KeySet方法就是这样的一个视图示例。它返回一个实现了Set接口的类对象,这个类的方法对原映射表进行操作。这种集合叫做视图。Views

  • 轻量级集包装器

Arrays.asList  Collections.nCopies

  • 子范围
  • 不可修改视图
  • 同步视图
  • 被检验视图

2. 批操作

3.集合与数组之间的转化

Arrays.asList

四.算法

1.排序和混排

Collections.sort()  Comparable和Comparator

降序排序:Collections.sort(items,Collections.reverseOrder())

2.二分查找法

Collections.binarySearch()

3.简单算法

学习笔记-java 集合的更多相关文章

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

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

  2. 软件测试之loadrunner学习笔记-02集合点

    loadrunner学习笔记-02集合点 集合点函数可以帮助我们生成有效可控的并发操作.虽然在Controller中多用户负载的Vuser是一起开始运行脚本的,但是由于计算机的串行处理机制,脚本的运行 ...

  3. [java学习笔记]java语言核心----面向对象之this关键字

    一.this关键字 体现:当成员变量和函数的局部变量重名时,可以使用this关键字来区别:在构造函数中调用其它构造函数 原理:         代表的是当前对象.         this就是所在函数 ...

  4. [java学习笔记]java语言核心----面向对象之构造函数

    1.构造函数概念 特点: 函数名与类名相同 不用定义返回值类型 没有具体的返回值 作用:                给对象进行初始化 注意: 默认构造函数 多个构造函数是以重载出现的 一个类中如果 ...

  5. 大数据学习笔记——Java篇之集合框架(ArrayList)

    Java集合框架学习笔记 1. Java集合框架中各接口或子类的继承以及实现关系图: 2. 数组和集合类的区别整理: 数组: 1. 长度是固定的 2. 既可以存放基本数据类型又可以存放引用数据类型 3 ...

  6. 大数据学习笔记——Java篇之IO

    IO学习笔记整理 1. File类 1.1 File对象的三种创建方式: File对象是一个抽象的概念,只有被创建出来之后,文件或文件夹才会真正存在 注意:File对象想要创建成功,它的目录必须存在! ...

  7. Java学习笔记 -- Java定时调度工具Timer类

    1 关于 (时间宝贵的小姐姐请跳过) 本教程是基于Java定时任务调度工具详解之Timer篇的学习笔记. 什么是定时任务调度 基于给定的时间点,给定的时间间隔或者给定的执行次数自动执行的任务. 在Ja ...

  8. 大数据学习笔记——Java篇之网络编程基础

    Java网络编程学习笔记 1. 网络编程基础知识 1.1 网络分层图 网络分层分为两种模型:OSI模型以及TCP/IP网络模型,前者模型分为7层,是一个理论的,参考的模型:后者为实际应用的模型,具体对 ...

  9. [Java学习笔记] Java异常机制(也许是全网最独特视角)

    Java 异常机制(也许是全网最独特视角) 一.Java中的"异常"指什么 什么是异常 一句话简单理解:异常是程序运行中的一些异常或者错误. (纯字面意思) Error类 和 Ex ...

随机推荐

  1. 江西理工大学南昌校区排名赛 D: 单身狗的物理游戏

    题目描述 萌樱花是一只单身狗. 萌樱花今天决定做一道理综物理题: 如图,两固定的绝缘斜面倾角均为θ,上沿相连.两细金属棒ab(仅标出a端)和cd(仅标出c端)长度均为L,质量分别为2m和m:用两根不可 ...

  2. LightOJ - 1245 根号n暴力

    打表或者画个图可以看出i>根号n时每个i的贡献值相差很小,可以利用公式优化(函数C) 但是注意不能一整段使用公式,否则复杂度还是会劣化到O(n)(显然对gongxian只能逐步递减) 网上看了不 ...

  3. hive安装 jdbc链接hive

    1. 下载hive安装包 2. 进入 conf 中  :  cp hive-default.xml.template hive-site.xml,  vi hive-site.xml 1)首行添加: ...

  4. 01背包----简单DP

    描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励的时刻了! 小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖品需要ne ...

  5. 【实战】简述一次挖XSS的经历

    值守尤其是夜班真的是件痛苦的事情呀,献给还在值守岗位上奋斗的小伙伴们. 简单试了前面几个参数,发现c0-id这个参数值在响应包里有回显,截图如下: 把c0-id参数值改为xss,响应包内容也随之变化, ...

  6. 分享个高精度IP定位

    https://www.opengps.cn/Data/IP/LocHighAcc.aspx

  7. PIE SDK地图放大镜

    放大镜,在地图的浏览过程中在主地图和次地图中起到很好的辅助作用, 要实现放大镜功能主要就是通过两个mapControl控件,主地图控件是mapControlMain,放大镜控件是UserControl ...

  8. TCP/IP协议分为哪四层,具体作用是什么。

    TCP/IP通讯协议采用了4层的层级结构,每一层都呼叫它的下一层所提供的网络来完成自己的需求.这4层分别为: 应用层:应用程序间沟通的层,如简单电子邮件传输(SMTP).文件传输协议(FTP).网络远 ...

  9. jquery将日期转换成指定格式的字符串

    引用jquery文件,如<script type="text/javascript" src="jquery-1.8.3.min.js"></ ...

  10. 案例42-使用ajax获取crm中的客户列表

    1webcontent部分 1 修改menu.jsp代码 2 jsp/customer/list.jsp代码 <%@ page language="java" content ...