Monday, 24 October 2016

Difference Between ArrayList and Vector in JAVA


 ArrayList and Vector both are the implementation class of List interface and use resizable array as a data structure internally and insertion order is preserved. However there are few differences between ArrayList and Vector.

ArrayList Vs Vector

1) Synchronization: ArrayList is non-synchronized that means multiple threads can work on ArrayList at the same time. For e.g. if one thread is performing an add operation on ArrayList, there can be an another thread performing remove operation on ArrayList at the same time in a multithreaded environment
while Vector is synchronized. This means if one thread is working on Vector, no other thread can get a hold of it. Unlike ArrayList, only one thread can perform an operation on vector at a time.
2) Resize: Both ArrayList and Vector can grow and shrink dynamically to maintain the optimal use of storage, however the way they resized is different. ArrayList grow by half of its size when resized while Vector doubles the size of itself by default when grows.
3) Performance: ArrayList gives better performance because it is non-synchronized. Vector operations gives poor performance as they are thread-safe.

4) Legacy : ArrayList is not a legacy class, because it is introduced in JDK 1.2 version, where as Vector is a legacy class introduced in JDK 1.0 version

2 comments:

  1. This comment has been removed by the author.

    ReplyDelete
  2. Hi sir. I'm a big fan of your blog. Your articles on java were useful in my interview.

    Cheers,
    https://www.flowerbrackets.com/arraylist-in-java/

    ReplyDelete