Difference between array and vector in java => http://emalumdel.nnmcloud.ru/d?s=YToyOntzOjc6InJlZmVyZXIiO3M6MjE6Imh0dHA6Ly9iaXRiaW4uaXQyX2RsLyI7czozOiJrZXkiO3M6NDM6IkRpZmZlcmVuY2UgYmV0d2VlbiBhcnJheSBhbmQgdmVjdG9yIGluIGphdmEiO30= It actually depends on our need. Earlier it was not a part of Collections. But if vectors are so wonderful, why even bother with arrays? In Java, a standard array is always of fixed length. It doesn't allocate each object dynamically, which would make access of middle list-items exceedingly slow; but it does allow for growth in the size of the list. So, you should have the prior knowledge of the length of the array you are using. Say you have a list size of 10 and its size will increase to 15 automatically when an add operation happens. There is a further very important point about ArrayList: These are not synchronized, hence are not thread-safe, ie, if your application needs to work as thread-safe at some point where a list is required, then discard ArrayList unless you take care of thread safety explicitly, which is obviously not correct way of doing. Indeed it is a high cost. Only one thread can enter into Vector object at any moment of time during execution. Time complexity of accessing an element is o 1 , while insertion and deletion has a time complexity of o n. Difference between ArrayList and Vector - When we start two or more threads within a program, there may be a situation when multiple threads try to access the same resource and finally they can produce unforeseen result due to concurrency issues. Arraylist vs Vector An arraylist can be seen as a dynamic array, which can grow in size. Vector can also be seen as an array that can grow in size. Vectors can be easily allocated and can be used to when the required size of the storage is not known until runtime. An arraylist can be seen as a dynamic array, which can grow in size. In Java, arraylists can only hold objects, they cannot hold primitive types directly you can put the primitive types inside an object or use the wrapper classes of the primitive types. Generally arraylists are provided with methods to perform insertion, deletion and searching. Time complexity of accessing an element is o 1while insertion and deletion has a time complexity of o n. In Java, arraylists can be traversed using foreach loops, iterators or simply using the indexes. In Java, arraylists were introduced from version 1. Vector is also an array that can grow in size. Vectors can be easily allocated and can be used when the required size of the storage is not known until runtime. Vectors also can only hold objects and cannot hold primitive types. Vectors are synchronized, therefore can be used safely in multithreaded environments. Vectors are provided with methods to add objects, delete objects and search objects. Similar to arraylist in java, vectors can be traversed using foreach loops, iterators or simply using the indexes. When it comes to Java, vectors have been included since the first version of Java. What is the difference between Arraylist and Vector. Even though both the arraylists and vectors are very similar to dynamic arrays that can grow in size, they have some important differences. The main difference between arraylists and vectors is that the vectors are synchronized whereas arraylists are unsynchronized. Therefore using arraylists in multithreaded environments will not be suitable, while vectors can be used safely in multithreaded environments since they are thread safe. But synchronization in vectors would cause a reduction in performance. Therefore it would be not difference between array and vector in java good idea to use vectors in a single threaded environment. Internally, both arraylists and vectors use arrays to hold objects. When the current space is not enough, vectors will double the size of its internal array, while arraylists increase the size of its internal array by 50%. But when using both the arraylists and vectors, by giving a suitable initial capacity, unnecessary resizing of the internal array can be avoided. In a situation that growth rate of data is known, using vectors would be more suitable since the incremental value of vectors could be defined.