What do you exactly mean by HashMap's iterator is fail-fast and HashTable's enumerator isn't?

后端 未结 3 1795
失恋的感觉
失恋的感觉 2021-02-03 10:31

I was looking up the difference between the two classes and this point came up in a lot of the answers with this blog being the source: http://javarevisited.blogspot.com/2010/1

相关标签:
3条回答
  • 2021-02-03 11:13

    Fail-fast means when you try to modify the content when you are iterating thru it, it will fail and throw ConcurrentModificationException.

    Set keys = hashMap.keySet();
    for (Object key : keys) {
        hashMap.put(someObject, someValue); //it will throw the ConcurrentModificationException here
    } 
    

    For HashTable enumeration:

     Enumeration keys = hashTable.keys();
     while (keys.hasMoreElements()) {
              hashTable.put(someKey, someValue);  //this is ok
        }
    
    0 讨论(0)
  • 2021-02-03 11:13

    The best way is to probably look at the source for each class as implemented by the Open JDK implementation for each class; that way, you can get your answer straight from the horse's mouth, as it were :-)

    That aside, essentially, "fail-fast" in this sense means that an Iterator over a HashMap will throw an exception if it detects that another thread has modified the targeted HashMap - if you look in the source for HashMap, you will see this is done by simply checking a counter for the number of expected modifications. If the modification count is different than the Iterator expected, that means that someone else has come in since the last check and messed around with the HashMap, and so the Iterator throws a ConcurrentModificationException.

    A "non fail-fast" Iterator wouldn't bother to check, and happily go along it's business in the underlying data structure. Therefore, you gain some flexibility (probably dubious flexibility in this case) in exchange for possibly running into errors later; i.e. attempting to access a value that is no longer present.

    As with all fail-fast strategies, the idea is that the earlier an error is detected, the easier it is to recover from or debug.

    0 讨论(0)
  • 2021-02-03 11:24

    When calling iterator.next(), if any modification has been made between the moment the iterator was created and the moment next() is called, a ConcurrentModificationException is immediately thrown. This is what fail-fast means.

    The Enumerations returned by Hashtable don't have this behavior. They assume you know what you're doing, and their behavior, AFAIK, is undefined if you modify the map while iterating over it using one of its enumerations.

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