您的位置:首页 > 理论基础 > 数据结构算法

Java基础知识强化之集合框架笔记72:集合特点和数据结构总结

2015-10-10 20:01 756 查看
1. 集合

(1)Collection(单列集合)

    List(有序,可重复):

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

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

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

    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:


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

   TreeMap:

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



    
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: