difference between linkedhashmap, hashmap, map, hashtable

前端 未结 3 2010
借酒劲吻你
借酒劲吻你 2021-02-04 22:55

I am preparing for software interviews and i am stuck with a question for days now.

I have not been able to figure out the difference between linkedhashmap, map, hashtab

相关标签:
3条回答
  • 2021-02-04 23:09

    All classes implement the Map interface and offer mostly the same functionality. The most important difference is the order in which iteration through the entries will happen:

    HashMap makes absolutely no guarantees about the iteration order. It can (and will) even change completely when new elements are added. TreeMap will iterate according to the "natural ordering" of the keys according to their compareTo() method (or an externally supplied Comparator). Additionally, it implements the SortedMap interface, which contains methods that depend on this sort order. LinkedHashMap will iterate in the order in which the entries were put into the map "Hashtable" is the generic name for hash-based maps. In the context of the Java API, Hashtable is an obsolete class from the days of Java 1.1 before the collections framework existed. It should not be used anymore, because its API is cluttered with obsolete methods that duplicate functionality, and its methods are synchronized (which can decrease performance and is generally useless). Use ConcurrrentHashMap instead of Hashtable.

    0 讨论(0)
  • 2021-02-04 23:10

    I doubt the differences can be explained significantly better than what's already written in the JavaDocs for these classes:

    • Map is the basic interface common to all these classes
    • a Hashtable is one implementation of that interface, for the "old" days when it was thought that having everything synchronized is a good idea (ref. Vector). It offers "kind of" thread-safety, if you know what you are doing. If you are serious about a map which can be used from multiple threads you should absolutely check out the ConcurrentHashMap and ConcurrentSkipListMap.
    • a HashMap is almost the same as a Hashtable, but with the synchronization removed. It's the preferred general-purpose Map implementation.
    • a LinkedHashMap additionally maintains a linked list of it's entries, which allows to maintain an ordering or use it as a LRU cache easily, just read the JavaDoc.

    All of the aforementioned Map implementations have their basic get/put operations in (amortized) O(1) time complexity. There are minor differences in the handling of null values, it's inevitable to check the JavaDoc for details.

    To get an idea of how these classes are implemeted, have a look at their inheritance tree:

    • Map (just the interface)
      • Dictionary (obsoleted abstract class)
        • Hashtable (the "old" map implementation lives on it's own)
      • AbstractMap (the basic functionality of the "new" map implementations)
        • HashMap (the first concrete map implementation for general purpose use)
          • LinkedHashMap (extends HashMap by mainaining the linked list)
    0 讨论(0)
  • 2021-02-04 23:23

    They all honor the same contract, but there are some differences in the implementation:

    • LinkedHashMap : keys are maintained in insertion order
    • HashTable : all operations are synchronized, no ordering guarantees
    • HashMap : no ordering guarantees, best performance

    Generally, the best practice is to use Map as the type for variables, and then you instantiate an implementing type based on the needs of your code. HashMap is generally preferred unless you need some ordering guarantees, in which case LinkedHashMap or TreeMap are good choices.

    0 讨论(0)
提交回复
热议问题