A problem
Map<Integer, Integer> map = new HashMap<>();
resMap.put(1.1);
System.out.println(map.get(1L));
System.out.println(map.get(1));
Copy the code
So if you look at this, what is the output of this code up here? I’ll reveal the answer later.
Source code analysis
HashMap get method source (add your own comment) :
public V get(Object key) {
Node<K,V> e;
return (e = getNode(hash(key), key)) == null ? null : e.value;
}
/**
* Implements Map.get and related methods.
*
* @param hash hash for key
* @param key the key
* @return the node, or null if none
*/
final Node<K,V> getNode(int hash, Object key) {
Node<K,V>[] tab; Node<K,V> first, e; int n; K k;
// If map is not empty
if((tab = table) ! =null && (n = tab.length) > 0 &&
(first = tab[(n - 1) & hash]) ! =null) {
// If the value is found directly through the passed key, it is returned directly
// 1) Compare the hash value of the passed key with the hash value of the node found in the map
// 2) Compare whether the key object passed in is equal to the key object of the node found in the corresponding position in the map
if (first.hash == hash && // always check first node((k = first.key) == key || (key ! =null && key.equals(k))))
return first;
// If the next node of the hash node is not empty, it is a linked list
if((e = first.next) ! =null) {
// If it is a red-black tree, it is a red-black tree
if (first instanceof TreeNode)
return ((TreeNode<K,V>)first).getTreeNode(hash, key);
// If it is a normal list, the list is iterated
do {
if(e.hash == hash && ((k = e.key) == key || (key ! =null && key.equals(k))))
return e;
} while((e = e.next) ! =null); }}// If none of the above is met, return null
return null;
}
Copy the code
If the hash value of the passed key matches the node in the map, two more judgments need to be made.
1) Compare the hash value of the passed key and the hash value of the node found at the corresponding position in the map
2) == Compare whether the key object passed in is equal to the key object of the node found in the corresponding position in the map ==
After looking at the above source code analysis, we publish the answer:
null
1
Copy the code
The final difference is this
(k = first.key) == key || (key ! =null && key.equals(k))
Copy the code
This code is equivalent to objects.equals (key, k).
This compares the key of the object stored in the map, named K, with the key passed to the map by the get method, named key.
Equivalent to comparing new Integer(1) and new Long(1L), we know that they are two different objects, so the results must not be equal. So when the key is 1L, it’s null.
conclusion
When the Map obtains a value, the key type does not match and the value cannot be obtained.