Collection框架介绍

CollectionList列表Set集, MapHashtableHashMapTreeMap

 

Collection  是单列集合

List   元素是有序的可重复

有序的 collection可以对列表中每个元素的插入位置进行精确地控制。

可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素。 

可存放重复元素,元素存取是有序的。

List接口中常用类

l Vector线程安全,但速度慢,已被ArrayList替代。

底层数据结构是数组结构

l ArrayList:线程不安全,查询速度快。

            底层数据结构是数组结构

l LinkedList:线程不安全。增删速度快。

             底层数据结构是列表结构

 

Set() 元素无序的、不可重复

取出元素的方法只有迭代器不可以存放重复元素,元素存取是无序的。

Set接口中常用的类

l HashSet线程不安全存取速度快。

          它是如何保证元素唯一性的呢?依赖的是元素的hashCode方法和euqals方法。

l TreeSet线程不安全,可以Set集合中的元素进行排序

          它的排序是如何进行的呢?通过compareTo或者compare方法中的来保证元素的唯一性元素是以二叉树的形式存放的。

 

 

Map  是一个双列集合

|--Hashtable:线程安全,速度快。底层是哈希表数据结构。是同步的。

不允许null作为键,null作为值。

      |--Properties:用于配置文件的定义和操作,使用频率非常高,同时键和值都是字符串。

是集合中可以和IO技术相结合的对象。(到了IO在学习它的特有和io相关的功能。)

|--HashMap:线程不安全,速度更快。底层也是哈希表数据结构。是不同步的。

允许null作为键,null作为值。替代了Hashtable.

      |--LinkedHashMap可以保证HashMap集合有序。存入的顺序和取出的顺序一致。

|--TreeMap:可以用来对Map集合中的进行排序.


 (关于HashMap和Hashtable的区别可参考:http://www.importnew.com/24822.html)

简单总结如下:

1.Hashtable是Dictionary的子类,HashMap是Map接口的一个实现类;
2.Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以使用Hashtable了;而对于HashMap,则需要额外的同步机制。但HashMap的同步问题可通过Collections的一个静态方法得到解决:
Map Collections.synchronizedMap(Map m)
这个方法返回一个同步的Map,这个Map封装了底层的HashMap的所有方法,使得底层的HashMap即使是在多线程的环境中也是安全的。
3.在HashMap中,null可以作为键,也可以作为value,(key不可重复,value可重复)这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用containsKey()方法来判断。

 

参考博文:https://blog.csdn.net/weixin_37766296/article/details/80436402



Collection 和 Collections的区别

 

Collection是集合类的上级接口接口主要有Set ListMap 

Collections是针对集合类的一个帮助类,提供了操作集合的工具方法一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。

猜你喜欢

转载自blog.csdn.net/weixin_37766296/article/details/80426151