To successfully store and retrieve objects from a hashtable, the objects used
as keys must implement the hashCode method and the equals method.
In a nutshell, since
null isn't an object, you can't call .equals() or .hashCode() on it, so the Hashtable can't compute a hash to use it as a key.HashMap is newer, and has more advanced capabilities, which are basically just an improvement on the Hashtable functionality. As such, when HashMap was created, it was specifically designed to handle null values as keys and handles them as a special case.
Specifically, the use of
null as a key is handled like this when issuing a .get(key):(key==null ? k==null : key.equals(k))
All Credit goes to cdeszaqOriginal Link: Why does Hashtable not take null key?
No comments:
Post a Comment