Documente Academic
Documente Profesional
Documente Cultură
www.topjavatutorial.com /java-interview-questions/java-collections-interview-questions/
The synchronized collections classes, Hashtable and Vector, and the synchronized wrapper classes,
Collections.synchronizedMap and Collections.synchronizedList, provide a basic conditionally thread-safe
implementation of Map and List. However, several factors make them unsuitable for use in highly concurrent
applications for example their single collection-wide lock is an impediment to scalability and it often becomes
necessary to lock a collection for a considerable time during iteration to prevent
ConcurrentModificationException.
1/3
5- What is ConcurrentHashMap in java ?
Best suited when you have multiple readers and few writers. Otherwise, performance degrades to
synchronized map or hashtable
allows multiple users to read simultaneously without any blocking
this is achieved by partitioning map into different parts depending on concurrency level and locking only a
portion of the map during updates.
Since update operations like put(), remove(), putall(),clear() are not synchronized, concurrent retrieval
may not reflect most recent change on the map.
All operations on concurrent hashmap are threadsafe.
creates a copy of underlying arraylist with every mutating operation ,i.e. add or set.
Normally very expensive as it involves costly array copy with every write operation. Use when iteration is
more than mutation.
threadsafe
iterator is fail-safe
Since the primary use of hashcode() is to determine in which slot to insert an object into the backing array
of hashtable/hashmap, a hashcode greater than Integet.MAX_VALUE can not be stored in an array
When a collections is ordered, it means you can iterate through the collection in a specific order,
A Hashtable collection is not ordered, where as an ArrayList is ordered by elements index position and
LinkedHashMap is ordered by the insertion order.
Some collections keep an order referred as natural order of elements.. those collections are not just ordered,
they are sorted. The natural order is specified the Comparable interface. But it is also possible to define other
sort orders using Comparator interface
10 Why String, Integer and other wrapper classes are considered good keys ?
2/3
String, Integer and other wrapper classes are natural candidates of HashMap key, and String is most frequently
used key as well because String is immutable and final,and overrides equals and hashcode() method.
Immutabiility is required, in order to prevent changes on fields used to calculate hashCode() because if key
object return different hashCode during insertion and retrieval than it wont be possible to get object from
HashMap. Immutability is best as it offers other advantages as well like thread-safety,
If you can keep your hashCode same by only making certain fields final, then you go for that as well. Since
equals() and hashCode() method is used during reterival of value object from HashMap, its important that key
object correctly override these methods and follow contact. If unequal object return different hashcode than
chances of collision will be less which subsequently improve performance of HashMap.
We can use any Object as key in Java HashMap provided it follows equals and hashCode contract and its
hashCode should not vary once the object is inserted into Map. If custom object is Immutable than this will be
already taken care because you can not change it once created.
Both can be used in multithreaded environment but once the size of Hashtable becomes considerable large
performance degrade because for iteration it has to be locked for longer duration.
Since ConcurrentHashMap introduced concept of segmentation , no matter how large it becomes only
certain part of it get locked to provide thread safety so many other readers can still access map without waiting
for iteration to complete.
In Summary ConcurrentHashMap only locked certain portion of Map while Hashtable lock full map while
doing iteration.
Hashtable is synchronized but ConcurrentHashMap provides better concurrency by only locking portion of map
determined by concurrency level. ConcurrentHashMap is certainly introduced after Hashtable and can be used
in place of it but Hashtable provide stronger thread-safety than ConcurrentHashMap.
ConcurrentHashMap is designed for concurrency and improve performance while HashMap which is non
synchronized by nature can be synchronized by applying a wrapper using Collections.synchronizedMap.
3/3