HashMap 和 Hashtable 有什么区别?
-
hashMap去掉了HashTable 的contains方法,但是加上了containsValue()和containsKey()方法。
-
hashTable同步的,而HashMap是非同步的,效率上逼hashTable要高。
-
hashMap允许空键值,而hashTable不允许。
如何决定使用 HashMap 还是 TreeMap?
对于在Map中插入、删除和定位元素这类操作,HashMap是最好的选择。然而,假如你需要对一个有序的key集合进行遍历,TreeMap是更好的选择。基于你的collection的大小,也许向HashMap中添加元素会更快,将map换为TreeMap进行有序key的遍历。
说一下 HashMap 的实现原理?
HashMap概述:HashMap是基于哈希表的Map接口的非同步实现。此实现提供所有可选的映射操作,并允许使用null值和null键。此类不保证映射的顺序,特别是它不保证该顺序恒久不变。
HashMap的数据结构:在java编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用这两个基本结构来构造的,HashMap也不例外。HashMap实际上是一个“链表散列”的数据结构,即数组和链表的结合体。
当我们往Hashmap中put元素时,首先根据key的hashcode重新计算hash值,根绝hash值得到这个元素在数组中的位置(下标),如果该数组在该位置上已经存放了其他元素,那么在这个位置上的元素将以链表的形式存放,新加入的放在链头,最先加入的放入链尾.如果数组中该位置没有元素,就直接将该元素放到数组的该位置上。
需要注意Jdk 1.8中对HashMap的实现做了优化,当链表中的节点数据超过八个之后,该链表会转为红黑树来提高查询效率,从原来的O(n)到O(logn)
说一下 HashSet 的实现原理?
-
HashSet底层由HashMap实现
-
HashSet的值存放于HashMap的key上
-
HashMap的value统一为PRESENT
相关代码::::::::::::::::::
package com.prac.demo.collectionEx;
import java.util.HashMap;
public class TestHash {
public static void main(String[] args) {
HashMap map=new HashMap(5);
map.put("1","one");
map.put("2","two");
Object three = map.put("3", "three");
Object four = map.put("3", "four");
System.out.println(three);//null
System.out.println(four);//three
/**
* hashmap的底层add()方法
* public boolean add(E e) {
* return map.put(e, PRESENT)==null;
* }
* *remove方法也是大体差不多
* 1.我们知道HashMap的put方法的***返回值***为(成功)null或者(失败)value。
* 如果put成功的话返回null,如果put失败的话,说明put的key已经存在了,就会返回已经存在该key的value值。
* 2.此时再回过头看hashset的add方法,如果底层hashmap的value保存的是null的话,那么put成功或者失败都会返回null,
* 那么HashSet的add()方法每次返回的布尔值都是true了,也就不能够确认add成功还是失败了。
*/
}
}