此类实现一个哈希表,大致与HashMap相同,但是任何非null对象才可以用作键值对,用作键的对象必须实现hashCode和equals方法;
1.jdk1.0开始可用
2.基于哈希表实现,由数组+链表;
3.默认数组长度为11,加载因子是0.75(百分之75),加载因子表示达到因子值需要扩容新的数组;
4.扩充方式为:原数组长度<<(乘2)+1;
5.线程安全的;
代码实现:
Map<String,String> map=new Hashtable<>();
map.put("One","佳佳");
map.put("Two","贝贝");
map.forEach((k,v)->System.out.println(k+"->"+v));
LinkedHashMap:HashMap的子类;
由Map接口的哈希表和链接列表实现,具有可预知迭代顺序,维护者一个运行于所有条目的双重链接列表;
由于HashMap不能保证顺序恒久不变,此类使用双重链表实现元素添加顺序的保持,可按照添加顺序保持不变;
代码实现:
Map<Integer,Integer> map=new LinkedHashMap<>();
map.put(1,11);
map.put(2,22);
map.forEach((k,v)->System.out.println(k+"->"+v));
本章对Java中的Hashtable和LinkedHashMap进行了概述和代码演示,这两个map实现类不怎么常用,知道即可;
有哪里不足或者有更好的建议,欢迎留言吐槽,有哪里不懂的小伙伴,可以私信我,我会一一答复,感谢认可,感谢支持!