Map 和 Set关系

Map和Set事实基础的朋友,有着千丝万缕的联系。

Map它可以被看作是Set延期。从何时起Set内容存储在key-value的值当表单。这个Set实际上可以作为Map使用。反过来,Map事实上,有一个Map.Entry内部接口。而Map在存放值对时,全然不考虑value,而仅仅考虑key,因此Map也能够看成是一个存key的Set,而value仅仅是key的附属物。

HashMap加入元素时,依据key的hashCode进行再哈希计算得到值来决定存放位置。HashMap底层有个数组Entry[],依据hash值来决定key-value存在数组的哪个元素,而Entry[]实际上是一个table。

HashSet底层是居于HashMap来实现的。HashSet底层用HashMap来保存全部元素,这些元素作为HashMap的key,而相应的Value是一个名为PRESENT的static final的Object对象。对HashSet操作的方法都调用HashMap的方法进行操作。

元素是否反复,要同一时候推断元素对象的hashCode()和equals(),hashCode相等且equals返还true时才觉得是反复元素,不进行替换。

TreeSet和TreeMap的关系也是非常相似的,即TreeSet底层是採用TreeMap存储的。TreeMap採用红黑树的排序二叉树来保存Map中的每一个Entry(树节点)。

List的三个实现:ArrayList,Vector和LinkedList。

Vector还有个儿子Stack,Stack不过在Vector的基础上加入了5个方法,只五个方法的代码就将Vector变成了Stack,Stack依旧是一个Vector,它继承了Vector的synchronized血统,都是线程安全的。从JDK1.6開始,Java提供了Deque接口并提供了实现类ArrayDeque,即使程序中须要栈这种数据结构,也不推荐使用Stack而推荐使用Deque。除非要求线程安全。

Deque是双端队列。是队列但同一时候拥有栈的功能。底层都是数组实现。

Vector差点儿被ArrayList取代了,它唯一的优点是线程安全。

如今甚至为了线程安全也不用Vector了。能够通过Collections工具类的synchronizedList()方法将一个普通的ArrayList包装成线程安全的ArrayList。

ArrayList 和LinkedList

ArrayList底层是基于数组实现的。所以ArrayList创建的时候有个初始的capacity,提供了构造方法,编程者能够在创建ArrayList时指定初始的capacity。假设没有显式提供capacity,那么程序默认设置为10.LinkedList是双向列表存储结构,不仅实现List接口,还实现Deque双端队列接口。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

最新文章

  1. 以Access为支撑,书写一个C#写入记录的案例
  2. Selenium Webdriver元素定位的常用方式
  3. AFHTTPClient的异步回调模式
  4. flex的Cairngorm框架
  5. 解决eclipse配置Tomcat时找不到server选项
  6. [Android教程]TextView使用SpannableString设置复合文本
  7. 最短路变形 poj3615&
  8. DM8168 DVRRDK软件框架研究
  9. fafu 1100 线段树
  10. 智表(ZCELL)专业版收费说明
  11. Codechef Bear and Clique Distances
  12. 17. Debuggers (调试器 5个)
  13. stark组件开发之组合搜索实现思路
  14. DbContext 和 ObjectContext两者的区别
  15. 如何在Anaconda中把python环境更新更高版本
  16. Shell 编程和Python编程的那些不同之处(一)
  17. [ZJOI2018]历史
  18. hive set 常用参数汇总
  19. python day27--网络编程
  20. lvs+nginx负载均衡

热门文章

  1. 工作经常使用的SQL整理,实战篇(三)
  2. atitit.标准时间格式 相互转换 秒数 最佳实践
  3. 深度分析DataTable如何筛选
  4. VBoxGuestAdditions.iso下载
  5. ORA-00913错误:PL/SQL: ORA-00913: too many values
  6. SlopOne推荐算法
  7. 使用 WPF 实现所见即所得HTML编辑器
  8. WPF技术触屏上的应用系列(一): 3D 图片(照片)墙、柱面墙(凹面墙或者叫远景墙、凸面墙或者叫近景墙)实现
  9. 小巧的UML工具-UMLet
  10. C日常语言实践中小(四)——勇者斗恶龙