HashTable与HashMap比较

1.HashTable是基于陈旧的Dictionary类的,Hashmap是java1.2引进的map接口的一个实现
2.HashTable的方法是同步的,HashMap不是,因此Hashtable是线程安全的,但是在执行效率上Hashtable要慢于Hashmap
3.HashMap允许空值与空键 但是HashTable不行
4.Hashmap 非同步实现map接口,是一个“链表数组”的结构,最大承载量是16,可以自动变长,由Entry()控制(key,value,next),hashCode()判断key是否重复
5.建议需要做同步的使用concurrentHashMap,降低了锁的力度,在HashMap的基础上,concurrentHashMap 将数据分为多个segment,默认16个(concurrency level)然后每次操作对一个level加锁,避免多线程锁的几率,提高并发效率,这里在并发读取时,除了key对应的value为null外,并没有使用锁!
Hashtable使用了锁的分段技术,减少了访问同一个锁的频率,从而提高了效率

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值