ArrayList
and LinkedList
both implements List interface
and their methods and results are almost identical. However there are few differences between them which make one better over another depending on the requirement.
ArrayList Vs LinkedList
1) Search:
ArrayList
search operation is pretty fast compared to the LinkedList
search operation. get(int index)
in ArrayList
gives the performance of O(1)
while LinkedList
performance is O(n)
.
Reason:
ArrayList
maintains index based system for its elements as it uses array data structure implicitly which makes it faster for searching an element in the list. On the other side LinkedList
implements doubly linked list which requires the traversal through all the elements for searching an element.
2) Deletion:
LinkedList
remove operation gives O(1)
performance while ArrayList
gives variable performance: O(n)
in worst case (while removing first element) and O(1)
in best case (While removing last element).
Conclusion: LinkedList element deletion is faster compared to ArrayList.
Reason: LinkedList’s each element maintains two pointers (addresses) which points to the both neighbor elements in the list. Hence removal only requires change in the pointer location in the two neighbor nodes (elements) of the node which is going to be removed. While In ArrayList all the elements need to be shifted to fill out the space created by removed element.
3) Inserts Performance:
LinkedList
add method gives O(1)
performance while ArrayList
gives O(n)
in worst case. Reason is same as explained for remove.
4) Memory Overhead:
ArrayList
maintains indexes and element data while LinkedList
maintains element data and two pointers for neighbor nodes
hence the memory consumption is high in LinkedList comparatively.
There are few similarities between these classes which are as follows:
- Both ArrayList and LinkedList are implementation of List interface.
- They both maintain the elements insertion order which means while displaying ArrayList and LinkedList elements the result set would be having the same order in which the elements got inserted into the List.
- Both these classes are non-synchronized and can be made synchronized explicitly by using Collections.synchronizedList method.
- The
iterator
andlistIterator
returned by these classes arefail-fast
(if list is structurally modified at any time after the iterator is created, in any way except through theiterator’s
own remove or add methods, the iterator willthrow
aConcurrentModificationException
).
When to use LinkedList and when to use ArrayList?
- As explained above the insert and remove operations give good performance
(O(1))
inLinkedList
compared toArrayList(O(n))
.Hence if there is a requirement of frequent addition and deletion in application then LinkedList is a best choice.
- Search (
get method
) operations are fast inArraylist (O(1))
but not inLinkedList (O(n))
so If there are less add and remove operations and more search operations requirement, ArrayList would be your best bet.