1. 集合

(1)Collection(单列集合)

    List(有序,可重复):

                              ArrayList:底层数据结构是数组,查询块,增删慢。线程不安全,效率高

              Vector:底层数据结构是数组,查询快,增删慢。线程安全,效率低

              LinkedList:底层数据结构是链表,查询慢,增删块。线程不安全,效率高。

    Set(无序,唯一):

              HashSet:底层数据结构是哈希表,哈希表依赖于两个方法:hashCode()和equals()。

                    执行顺序:

                      首先判断hashCode()值是否相同 ?

                                    是:继续执行equals(),看其返回值

                                      是true:说明元素重复,不添加

                                      是false:就直接添加到集合

                                  否:就直接添加到集合

                      最终:

                        自动生成hashCode()和equals()即可.

                       LinkedHashSet:底层数据结构由链表和哈希表组成。

                                                                                     由链表保证元素的有序,由哈希表保证元素的唯一。

              TreeSet:

                     底层数据结构是红黑树(是一种自平衡的二叉树)

                   如何保证元素的唯一性?

                          根据比较的返回值是否是0来决定

                   如何保证元素的排序呢?

                              两种方式:

                              自然排序(元素具备比较性)

                                  让元素所属的类实现Comparable接口

                              比较器排序(集合具备比较性)

                                  让集合接收一个Comparator的实现类对象

(2)Map(双列集合)

• Map集合的数据结构仅仅针对键有效,与值无关。

• 存储的是键值对形式的元素,键唯一,值可重复。

    HashMap:

       底层数据结构是哈希表。线程不安全,效率高
          哈希表依赖两个方法:hashCode()和equals()
          执行顺序:
            首先判断hashCode()值是否相同
                是:继续执行equals(),看其返回值
                    是true:说明元素重复,不添加
                    是false:就直接添加到集合
                否:就直接添加到集合
          最终:
            自动生成hashCode()和equals()即可

       LinkedHashMap:

            底层数据结构由链表和哈希表组成。
            由链表保证元素有序。
            由哈希表保证元素唯一。

    Hashtable:

          底层数据结构是哈希表。线程不安全,效率低
              哈希表依赖两个方法:hashCode()和equals()
            执行顺序:
              首先判断hashCode()值是否相同
                 是:继续执行equals(),看其返回值
                     是true:说明元素重复,不添加
                     是false:就直接添加到集合
                 否:就直接添加到集合
              最终:
               自动生成hashCode()和equals()即可

   TreeMap:

     底层数据结构是红黑树。(是一种自平衡的二叉树)
        如何保证元素唯一性呢?
            根据比较的返回值是否是0来决定
        如何保证元素的排序呢?
            两种方式
              自然排序(元素具备比较性)
                让元素所属的类实现Comparable接口
              比较器排序(集合具备比较性)
                让集合接收一个Comparator的实现类对象

    

Java基础知识强化之集合框架笔记72:集合特点和数据结构总结的更多相关文章

  1. Java基础知识强化之IO流笔记72:NIO之 NIO核心组件(NIO使用代码示例)

    1.Java NIO 由以下几个核心部分组成: Channels(通道) Buffers(缓冲区) Selectors(选择器) 虽然Java NIO 中除此之外还有很多类和组件,Channel,Bu ...

  2. Java基础知识强化之IO流笔记68:Properties和IO流集合使用

    1. Properties和IO流集合使用 这里的集合必须是Properties集合:  public void load(Reader reader):把文件中的数据读取到集合中  public v ...

  3. Java基础知识强化之IO流笔记77:NIO之 Selector

    Selector(选择器)是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件.这样,一个单独的线程可以管理多个channel,从而管理多个网络连接. 1.  ...

  4. Java基础知识强化之IO流笔记69:Properties练习之 判断文件中是否有指定的键,如果有就修改值的案例

    1. 我有一个文本文件(user.txt),我知道数据是键值对形式的,但是不知道内容是什么. 请写一个程序判断是否有"lisi"这样的键存在,如果有就改变其值为"100& ...

  5. Java基础知识强化之IO流笔记51:IO流练习之 键盘录入学生信息按照总分排序写入文本文件中的案例

    1.  键盘录入学生信息(姓名,语文成绩,数学成绩,英语成绩),按照总分排序写入文本文件中 分析:   A:创建学生类   B:创建集合对象      TreeSet<Student>   ...

  6. Java基础知识强化之IO流笔记66:Properties的概述 和 使用(作为Map集合使用)

    1. Properties的概述  Properties:属性集合类.是一个可以和IO流相结合使用的集合类. 该类主要用于读取以项目的配置文件(以.properties结尾的文件 和 xml文件). ...

  7. Java基础知识强化之IO流笔记46:IO流练习之 把文本文件中数据存储到集合中的案例

    1.  把文本文件中数据存储到集合中      需求:从文本文件中读取数据(每一行为一个字符串数据)到集合中,并遍历集合. 分析:      通过题目的意思我们可以知道如下的一些内容,      数据 ...

  8. Java基础知识强化之IO流笔记45:IO流练习之 把集合中的数据存储到文本文件案例

    1. 把集合中的数据存储到文本文件案例:    需求:把ArrayList集合中的字符串数据存储到文本文件 ? (1)分析:通过题目的意思我们可以知道如下的一些内容,ArrayList集合里存储的是字 ...

  9. Java基础知识强化之网络编程笔记18:Android网络通信之 使用HttpClient的Post / Get 方式读取网络数据(基于HTTP通信技术)

    使用HttpClient进行Get方式通信,通过HttpClient建立网络链接,使用HttpGet方法读取数据,并且通过Response获取Entity返回值. 使用HttpClient进行Post ...

  10. Java基础知识强化之网络编程笔记17:Android网络通信之 使用Http的Post方式读取网络数据(基于HTTP通信技术)

    使用Http的Post方式与网络交互通信.Post方式需要向网络传输一部分数据,同时具有输入流和输出流. 详见:Android(java)学习笔记210:采用post请求提交数据到服务器(qq登录案例 ...

随机推荐

  1. bzoj2039

    还是同一类最小割问题 对于只要记住,建图是来最小化损失, 最大化收益是所有收益-最小取不到的收益 首先对于每个经理i,如果不取,必然有signma(w[i,j])收益会得不到(这里我们先不考虑额外的损 ...

  2. Asp.net性能优化技巧

    [摘 要] 我只是提供我几个我认为有助于提高写高性能的asp.net应用程序的技巧,本文提到的提高asp.net性能的技巧只是一个起步,更多的信息请参考<Improving ASP.NET Pe ...

  3. Python‘ssl.match_hostname()’函数SSL证书验证安全绕过漏洞

    漏洞名称: Python‘ssl.match_hostname()’函数SSL证书验证安全绕过漏洞 CNNVD编号: CNNVD-201312-033 发布时间: 2013-12-04 更新时间: 2 ...

  4. Linux使用sudo提权时,出现xx 不在 sudoers 文件中。此事将被报告。visudo 命令简单介绍。

    在使用 sudo 临时提权时,出现:不在 sudoers 文件中.此事将被报告. 可以使用 visudo命令 来配置/etc/sudoers文件,将目标用户赋予使用sudo命令的能力. visudo命 ...

  5. leetcode 逆转字符串 当年的第一题,今天再写一遍,物是人非

    public class Solution { public String reverseWords(String s) { if(s==null||s.length()==0) return &qu ...

  6. Html笔记(三)列表

    列表标签: <dl> <dt>:上层标签 <dd>:下层标签 例: <dl> <dt>上层项目</dt> <dd>下 ...

  7. NOIP2015 提高组(senior) 解题报告

    过了这么久才来发解题报告,蒟蒻实在惭愧 /w\ Day1 T1 [思路] 模拟 [代码] #include<iostream> #include<cstring> #inclu ...

  8. HW5.2

    import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...

  9. 杭电HDOJ--ACM1002(JAVA解题,运用BigInteger)(自定义MBigInteger 简单实现大数处理----完善后可以实现百亿计算器)

    转载声明:原文转自http://www.cnblogs.com/xiezie/p/5501901.html     JAVA解题:   import java.util.*; import java. ...

  10. ZOJ-2365 Strong Defence 贪心,BFS

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2365 我没看懂题目...这样理解:一个有向图,要给一些边染色,使 ...