博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HashMap、TreeMap和HashTable的区别
阅读量:4915 次
发布时间:2019-06-11

本文共 539 字,大约阅读时间需要 1 分钟。

Map接口有三个比较重要的实现类,分别是HashMap、TreeMap和HashTable。

TreeMap是有序的,HashMap和HashTable是无序的。

Hashtable的方法是同步的,HashMap的方法不是同步的。这是两者最主要的区别。

这就意味着Hashtable是线程安全的,HashMap不是线程安全的。HashMap效率较高,Hashtable效率较低。 如果对同步性或与遗留代码的兼容性没有任何要求,建议使用HashMap。 查看Hashtable的源代码就可以发现,除构造函数外,Hashtable的所有 public 方法声明中都有 synchronized关键字,而HashMap的源码中则没有。

Hashtable不允许null值,HashMap允许null值(key和value都允许)

父类不同:Hashtable的父类是Dictionary,HashMap的父类是AbstractMap

Hashtable中hash数组默认大小是11,增加的方式是 old*2+1。

HashMap中hash数组的默认大小是16,而且一定是2的指数。

转载于:https://www.cnblogs.com/sidekick/p/8010522.html

你可能感兴趣的文章
项目实战02:nginx 反向代理负载均衡、动静分离和缓存的实现
查看>>
BZOJ3139/BZOJ1306 HNOI2013比赛/CQOI2009循环赛(搜索)
查看>>
C语言反汇编入门实例
查看>>
tab标签页
查看>>
IDEA快捷键
查看>>
冻结页面
查看>>
Scala-数组
查看>>
【计算机视觉】opencv读取多个摄像头
查看>>
【VS开发】MP4与H.264
查看>>
【Qt开发】V4L2 API详解 Camera详细设置
查看>>
谷歌弃用图片验证码,从此告别奇葩验证码
查看>>
JavaScript学习-require的用法
查看>>
libevent源码分析:epoll后端实现
查看>>
iOS和Android的app界面设计规范(转)
查看>>
【转】关于zend studio 9的4空格替换tab
查看>>
Apache Maven 入门篇(下)
查看>>
HTML 基础 2
查看>>
nginx配置
查看>>
jquery插件
查看>>
tar的基础用法
查看>>