Java8改进的HashMap和Hashtable实现类
来源:互联网 发布:1.5v单片机 温湿度测量 编辑:程序博客网 时间:2024/06/05 15:10
HashMap和Hashtable都是Map接口的典型实现类,它们之间的关系完全类似于ArrayList和Vector的关系:Hashtable是一个古老的Map实现类,它从JDK1.0起就已经出现了,当它出现时,Java还没有提供Map接口,所以它包含了两个繁琐的方法,即elements()(类似于Map接口定义的values()方法)和keys()(类似于Map接口定义的keySet()方法),现在很少使用这两个方法(关于这两个方法的用法请参考)
Java8改进了HashMap的实现,使用HashMap存在key冲突时依然具有较好的性能。
除此之外,Hashtable和HashMap存在两点典型区别。
(1)Hashtable是一个线程安全的Map实现,但HashMap是线程不安全的实现,所以HashMap比Hashtable的性能高一点;但如果有多个线程访问同一个Map对象时,使用Hashtable实现类会更好。
(2)Hashtable不允许使用null作为key和value,如果试图把null放进Hashtable中,将会引发空指针异常;但HashMap可以使用null作为key或value。
由于HashMap里的key不能重复,所以HashMap里最多只有一个key-value对的key为null,但可以有无数多个key-value对的value为null.
下面程序示范了用null值作为HashMap的key和value的情形。
package com.zhao.three;import java.util.HashMap;public class NullInHashMap {public static void main(String[] args) {HashMap hm=new HashMap<>();hm.put(null, null);hm.put(null, null);hm.put("a", null);System.out.println(hm);}}
上面程序试图向HashMap中放入三个key-value对,其中第二行代码处无法将key-value对放入,因为Map中已经有一个key-value对的key为null值,所以无法再放入key为null值的key-value对。第三行代码处可以放入该key-value对,因为一个HashMap中可以有多个value为null值。编译、运行上面程序,看到如下输出结果;
0 0
- Java8改进的HashMap和Hashtable实现类
- Java8改进的HashMap和Hashtable实现类
- java8改进的HashMap和Hashtable类
- Java8---4.对HashMap和ConcurrentHashMap的改进
- java8中HashMap相对于java7的改进
- java---Map接口的实现类HashMap和Hashtable
- HashMap和Hashtable的实现原理
- HashMap和Hashtable的实现原理
- java8中Hashmap改进
- Hashtable和HashMap类
- java8 HashMap的底层实现
- Hashtable类和HashMap类的区别
- Hashtable和HashMap类的区别
- Hashtable和HashMap类的区别
- Hashtable和HashMap类的区别
- Hashtable和HashMap类的区别
- Hashtable和HashMap类的不同
- Hashtable和HashMap类的区别
- 基于request.getAttribute与request.getParameter的区别详解
- file上传文件,js中获取文件大小
- 知晓当前是在哪一个活动
- xfire设置连接超时问题
- Struts 2 override the interceptor parameters
- Java8改进的HashMap和Hashtable实现类
- 虚函数的实现原理--c++虚函数表解析
- git 点滴
- Cocoa和Cocoa Touch介绍
- xshell连接不了opensuse linux解决办法
- Git基础- 远程仓库操作
- HashMap实现原理分析
- 关于表单提交的两种方式,post和get
- 利用Div设计TabControl效果