As we already know Collections which is nothing but collections of Objects where we deals with the Objects using some pre-defined methods. But There are several problems which occurs when we use Collections concept in multi-threading. The problems which occurs while using Collections in Multi-threaded application:
- Most of the Collections classes objects (like ArrayList, LinkedList, HashMap etc) are non-synchronized in nature i.e. multiple threads can perform on a object at a time simultaneously. Therefore objects are not thread-safe.
- Very few Classes objects (like Vector, Stack, HashTable) are synchronized in nature i.e. at a time only one thread can perform on an Object. But here the problem is performance is low because at a time single thread execute an object and rest thread has to wait.
- The main problem is when one thread is iterating an Collections object then if another thread cant modify the content of the object. If another thread try to modify the content of object then we will get RuntimeException saying ConcurrentModificationException.
- Because of the above reason Collections classes is not suitable or we can say that good choice for Multi-threaded applications.
To overcome the above problem SUN microSystem introduced a new feature in JDK 1.5Version, which is nothing but Concurrent Collections.
Exception in thread “main” java.util.ConcurrentModificationException
Attention reader! Don’t stop learning now. Get hold of all the important Java and Collections concepts with the Fundamentals of Java and Java Collections Course at a student-friendly price and become industry ready.
- Difference between Traditional Collections and Concurrent Collections in java
- Java.util.concurrent.CyclicBarrier in Java
- Java.util.concurrent.Semaphore class in Java
- Java.util.concurrent.RecursiveAction class in Java with Examples
- Java.util.concurrent.Phaser class in Java with Examples
- Java.util.concurrent.RecursiveTask class in Java with Examples
- Different Approaches to Concurrent Programming in Java
- Java.util.concurrent.Exchanger class with Examples
- Java.util.concurrent.Executor interface with Examples
- Java.util.concurrent.ExecutorService interface with Examples
- Main App Implements Runnable | Concurrent Programming Approach 2
- Inner Class And Anonymous Inner Class that Implements Runnable | Concurrent Programming Approach 3
- Lambda Expressions | Concurrent Programming Approach 4
- Java.util.Collections.rotate() Method in Java with Examples
- Java.util.Collections.frequency() in Java
- Java.util.Collections.frequency() in Java with Examples
- Java.util.Collections.disjoint() Method in java with Examples
- Collections.sort() in Java with Examples
- Collections.binarySearch() in Java with Examples
- Collections.reverse() in Java with Examples
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.