Prev Next

Java / Map and its implementations

How hash collision is handled in HashMap?

Prior to Java8, map implementations such as Hashmap handles collision by chaining using a linked list when multiple elements (key) end up in same bucket location. This may degrade the performance from O(1) (one bucket location one key) to O(n) for that particular bucket.

In Java8, to address the performance degrade due to frequent collision, Java8 has started using a balanced tree instead of linked list for storing collided entries to improve performance from O(n) to O(log n).

Java8 still uses Linked list for collision however it converts to balanced tree when number of elements in the same bucket exceeds the TREEIFY_THRESHOLD constant defined by Hashmap. The TREEIFY_THRESHOLD value is 8 so when number of elements exceed 8 linked list switches to balanced tree.

It's right time to invest in Cryptocurrencies Dogecoin! Earn free bitcoins up to $250 now by signing up.

Earn bitcoins upto $250 (free), invest in other Cryptocurrencies when you signup with blockfi. Use the referral link: Signup now and earn!

Using BlockFi, don't just buy crypto - start earning on it. Open an interest account with up to 8.6% APY, trade currencies, or borrow money without selling your assets.


Join CoinBase! We'll both receive $10 in free Bitcoin when they buy or sell their first $100 on Coinbase! Available in India also. Use the referral Join coinbase!


Invest now!!! Get Free equity stock (US, UK only)!

Use Robinhood app to invest in stocks. It is safe and secure. Use the Referral link to claim your free stock when you sign up!.

The Robinhood app makes it easy to trade stocks, crypto and more.


Webull! Receive free stock by signing up using the link: Webull signup.

More Related questions...

List the differences between HashTable and HashMap in Java collections. Similarities between HashMap and HashTable in Java. What is a resource bundle in Java? What is the Big-O notation for operations in a Hashmap? Is HashMap faster compared to ArrayList in terms of search? Difference between HashMap and ConcurrentHashMap. Is ConcurrentHashmap good for frequently updating concurrent data structure? What are the commonly used implementations of Map in Java? Difference between Collections.synchronizedMap(Map) and ConcurrentHashMap. Difference between Collections.synchronizedMap and Hashtable. Why is ConcurrentHashMap faster than Hashtable in Java? What are the different Reference types available in Java? Which methods you need to override to use an object as key in HashMap ? Why Map does not extend the Collection interface in Java Collections Framework? How Remove method works internally in Java HashMap? Explain NavigableMap in Java collection. Explain rehashing process in Java HashMap. How null key is handled in HashMap? What is the data-structure behind the Java HashMap implementation? Why are immutable objects in HashMap so effective? Why null is not allowed in ConcurrentHashmap? Does ConcurrentHashMap allow null keys and null values ? Difference between remove() and clear() methods in HashMap. Is hashcode method invoked internally when calling get and put method in Java? How hash collision is handled in HashMap? What are the interfaces that TreeMap implements? What interfaces that HashMap implements? Big O notation for TreeMap in Java. Is TreeMap synchronized in Java? Does TreeMap allow null key? Key object constraints on a TreeMap. Does IdentityHashMap use hashcode method? What design pattern that Collections.synchronizedMap implement? Does EnumMap allow null key? Difference between HashMap and IdentityHashMap. What is a ConcurrentSkipListMap? How do you sort a TreeMap by comparing its value? Default initial table size of ConcurrentHashMap. Does Map implement Iterable?
Show more question and Answers...

Queue and its implementations

Comments & Discussions