美文网首页JAVA开发工作总结
Java集合中List,Set以及Map等集合体系详解

Java集合中List,Set以及Map等集合体系详解

作者: 暴走的狐狸 | 来源:发表于2023-01-16 11:55 被阅读0次

List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口

Set下有HashSet,LinkedHashSet,TreeSet

List下有ArrayList,Vector,LinkedList

Map下有Hashtable,LinkedHashMap,HashMap,TreeMap

collection接口下还有个Queue接口,有PriorityQueue类

注意:

Queue接口与List、Set同一级别,都是继承了collection接口。

看图你会发现,LinkedList既可以实现Queue接口,也可以实现List接口.只不过呢, LinkedList实现了Queue接口。Queue接口窄化了对LinkedList的方法的访问权限(即在方法中的参数类型如果是Queue时,就完全只能访问Queue接口所定义的方法 了,而不能直接访问 LinkedList的非Queue的方法),以使得只有恰当的方法才可以使用。

SortedSet是个接口,它里面的(只有TreeSet这一个实现可用)中的元素一定是有序的。

总结:

connection接口(注意首字母小写):

— List 有序,可重复

ArrayList

优点: 底层数据结构是数组,查询快,增删慢。

缺点: 线程不安全,效率高

Vector

优点: 底层数据结构是数组,查询快,增删慢。

缺点: 线程安全,效率低

LinkedList

优点: 底层数据结构是链表,查询慢,增删快。

缺点: 线程不安全,效率高

—Set 无序,唯一

HashSet

底层数据结构是哈希表。(无序,唯一)

如何来保证元素唯一性?

1.依赖两个方法:hashCode()和equals()

LinkedHashSet

底层数据结构是链表和哈希表。(FIFO插入有序,唯一)

1.由链表保证元素有序

2.由哈希表保证元素唯一

TreeSet

底层数据结构是红黑树。(唯一,有序)

1. 如何保证元素排序的呢?

自然排序

比较器排序

2.如何保证元素唯一性的呢?

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

针对collection集合我们到底使用谁呢?(掌握)

唯一吗?

是:Set

排序吗?

是:TreeSet或LinkedHashSet

否:HashSet

如果你知道是Set,但是不知道是哪个Set,就用HashSet。

否:List

要安全吗?

是:Vector

否:ArrayList或者LinkedList

查询多:ArrayList

增删多:LinkedList

如果你知道是List,但是不知道是哪个List,就用ArrayList。

如果你知道是collection集合,但是不知道使用谁,就用ArrayList。

如果你知道用集合,就用ArrayList。

说完了collection,来简单说一下Map.

相关文章

  • Java基础——集合体系Map详解

    Java基础——集合体系Map详解 上文中我们了解了集合体系中的单列集合:Java基础——集合以及Java集合——...

  • Java基础之集合框架

    一、Java集合类简介: Java集合大致可以分为Set、List、Queue和Map四种体系。 其中Set代表无...

  • JAVA集合

    java集合分类 Java集合大致可以分为Set、List、Queue和Map四种体系,其中Set代表无序、不可重...

  • JAVA:Set/List/Map 集合(一)

    Java集合大致可分为:Set,List和Map 三种体系,其中Set代表无序、不可重复的集合;List代表有序、...

  • 集合的继承体系,迭代器

    -java集合可分为set,list,map三种体系,其中set代表无序,不可重复的集合,list代表有序可重复的...

  • java——集合、多线程

    集合 java中的集合一般分为List、Map、Set、Queue。 List 列表集合 ArrayList:最常...

  • Java中的集合

    Java集合体系 Set(接口):代表无序、不可重复的集合 List(接口):代表有序、重复的集合 Map(接口)...

  • Java 集合

    Java集合分4种体系:Set List Queue Map集合与数组的区别:集合可以保存数量不定的数据;集合可以...

  • Java集合中List,Set以及Map等集合体系详解

    List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有Hash...

  • 每天进步一点系列一:java的集合类的差别

    java集合的体系结构 List、Set、Map是这个集合体系中最主要的三个接口。 其中List和Set继承自Co...

网友评论

    本文标题:Java集合中List,Set以及Map等集合体系详解

    本文链接:https://www.haomeiwen.com/subject/hdtbgqtx.html