ArrayList and LinkedList both implements List interface and maintains insertion order. Both are non synchronized classes.
However, there are many differences between ArrayList and LinkedList classes that are given below.
|
ArrayList |
LinkedList |
|
1) ArrayList
internally uses a dynamic
array to store the elements. |
LinkedList
internally uses a doubly
linked list to store the elements. |
|
2) Manipulation
with ArrayList is slow because
it internally uses an array. If any element is removed from the array, all
the bits are shifted in memory. |
Manipulation with
LinkedList is faster than
ArrayList because it uses a doubly linked list, so no bit shifting is
required in memory. |
|
3) An ArrayList
class can act
as a list only because it implements List only. |
LinkedList class
can act as a
list and queue both because it implements List and Deque
interfaces. |
|
4) ArrayList
is better for
storing and accessing data. |
LinkedList is better for manipulating data. |
Example of ArrayList and LinkedList in Java
Let's see a simple example where we are using ArrayList and LinkedList both.
Output:
arraylist: [Ravi,Vijay,Ravi,Ajay] linkedlist: [James,Serena,Swati,Junaid]

0 Comments