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的实现类对象

    

最新文章

  1. 求排列组合数C(n,m) φ(゜▽゜*)♪
  2. UNET学习笔记3 - 网络系统的概念
  3. Kafka单机环境部署
  4. [SAP ABAP开发技术总结]将文件存储到数据库表中,并可发送邮件
  5. 存储过程的参数问题与C#中的调用
  6. POJ-3522 Slim Span(最小生成树)
  7. 自学Python5.1-模块简介
  8. 织梦DEDE网站后台如何上传附件
  9. 如何给PDF文件制作书签
  10. TCP聊天工具的实现
  11. [node.js] fs.renameSync()报错
  12. SV processses
  13. jsp标签之jsp:setProperty用法
  14. Samsung_tiny4412(驱动笔记06)----list_head,proc file system,GPIO,ioremap
  15. Problem1-Project Euler
  16. HTML5 的新特性以及新标签的浏览器兼容问题
  17. 【ssh免登录】设置集群环境ssh免登录步骤
  18. Redhat安装python环境(readline模块)
  19. MySQL常用:Got a packet bigger than 'max_allowed_packet' bytes & MySQL开远程服务
  20. model.find(options)

热门文章

  1. 【HDOJ】1074 Doing Homework
  2. tlplayer,wzplayer支持wince,winphone,windows8 for arm
  3. 放在jsp头部的代码
  4. org.apache.hadoop.io.LongWritable cannot be cast to org.apache.hadoop.io.Text
  5. git引用^和~的区别
  6. 第4章 类型基础 -- 4.1 所有类型都从System.Object派生
  7. puppet案例
  8. KMP学习总结
  9. 坑爹的IE quirk模式【转】
  10. Sql FAQ