Package java.util
Class Vector<E>
java.lang.Object
java.util.AbstractCollection<E>
java.util.AbstractList<E>
java.util.Vector<E>
- Type Parameters:
E- The element type of this list.
- All Implemented Interfaces:
Serializable,Cloneable,Iterable<E>,Collection<E>,List<E>,RandomAccess
- Direct Known Subclasses:
Stack
public class Vector<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, Serializable
Vector is an implementation of
List, backed by an array and synchronized.
All optional operations including adding, removing, and replacing elements are supported.
All elements are permitted, including null.
This class is equivalent to ArrayList with synchronized operations. This has a
performance cost, and the synchronization is not necessarily meaningful to your application:
synchronizing each call to get, for example, is not equivalent to synchronizing on the
list and iterating over it (which is probably what you intended). If you do need very highly
concurrent access, you should also consider CopyOnWriteArrayList.
- See Also:
- Serialized Form
-
Field Summary
Fields Modifier and Type Field Description protected intcapacityIncrementHow many elements should be added to the vector when it is detected that it needs to grow to accommodate extra entries.protected intelementCountThe number of elements or the size of the vector.protected Object[]elementDataThe elements of the vector.Fields inherited from class java.util.AbstractList
modCount -
Constructor Summary
Constructors Constructor Description Vector()Constructs a new vector using the default capacity.Vector(int capacity)Constructs a new vector using the specified capacity.Vector(int capacity, int capacityIncrement)Constructs a new vector using the specified capacity and capacity increment.Vector(Collection<? extends E> collection)Constructs a new instance ofVectorcontaining the elements incollection. -
Method Summary
Modifier and Type Method Description voidadd(int location, E object)Adds the specified object into this vector at the specified location.booleanadd(E object)Adds the specified object at the end of this vector.booleanaddAll(int location, Collection<? extends E> collection)Inserts the objects in the specified collection at the specified location in this vector.booleanaddAll(Collection<? extends E> collection)Adds the objects in the specified collection to the end of this vector.voidaddElement(E object)Adds the specified object at the end of this vector.intcapacity()Returns the number of elements this vector can hold without growing.voidclear()Removes all elements from this vector, leaving it empty.Objectclone()Returns a new vector with the same elements, size, capacity and capacity increment as this vector.booleancontains(Object object)Searches this vector for the specified object.booleancontainsAll(Collection<?> collection)Searches this vector for all objects in the specified collection.voidcopyInto(Object[] elements)Attempts to copy elements contained by thisVectorinto the corresponding elements of the suppliedObjectarray.EelementAt(int location)Returns the element at the specified location in this vector.Enumeration<E>elements()Returns an enumeration on the elements of this vector.voidensureCapacity(int minimumCapacity)Ensures that this vector can hold the specified number of elements without growing.booleanequals(Object object)Compares the specified object to this vector and returns if they are equal.EfirstElement()Returns the first element in this vector.Eget(int location)Returns the element at the specified location in this vector.inthashCode()Returns an integer hash code for the receiver.intindexOf(Object object)Searches in this vector for the index of the specified object.intindexOf(Object object, int location)Searches in this vector for the index of the specified object.voidinsertElementAt(E object, int location)Inserts the specified object into this vector at the specified location.booleanisEmpty()Returns if this vector has no elements, a size of zero.ElastElement()Returns the last element in this vector.intlastIndexOf(Object object)Searches in this vector for the index of the specified object.intlastIndexOf(Object object, int location)Searches in this vector for the index of the specified object.Eremove(int location)Removes the object at the specified location from this vector.booleanremove(Object object)Removes the first occurrence, starting at the beginning and moving towards the end, of the specified object from this vector.booleanremoveAll(Collection<?> collection)Removes all occurrences in this vector of each object in the specified Collection.voidremoveAllElements()Removes all elements from this vector, leaving the size zero and the capacity unchanged.booleanremoveElement(Object object)Removes the first occurrence, starting at the beginning and moving towards the end, of the specified object from this vector.voidremoveElementAt(int location)Removes the element found at index positionlocationfrom thisVector.protected voidremoveRange(int start, int end)Removes the objects in the specified range from the start to the, but not including, end index.booleanretainAll(Collection<?> collection)Removes all objects from this vector that are not contained in the specified collection.Eset(int location, E object)Replaces the element at the specified location in this vector with the specified object.voidsetElementAt(E object, int location)Replaces the element at the specified location in this vector with the specified object.voidsetSize(int length)Sets the size of this vector to the specified size.intsize()Returns the number of elements in this vector.List<E>subList(int start, int end)Returns a List of the specified portion of this vector from the start index to one less than the end index.Object[]toArray()Returns a new array containing all elements contained in this vector.<T> T[]toArray(T[] contents)Returns an array containing all elements contained in this vector.StringtoString()Returns the string representation of this vector.voidtrimToSize()Sets the capacity of this vector to be the same as the size.Methods inherited from class java.util.AbstractList
iterator, listIterator, listIteratorMethods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.List
iterator, listIterator, listIterator
-
Field Details
-
elementCount
protected int elementCountThe number of elements or the size of the vector. -
elementData
The elements of the vector. -
capacityIncrement
protected int capacityIncrementHow many elements should be added to the vector when it is detected that it needs to grow to accommodate extra entries. If this value is zero or negative the size will be doubled if an increase is needed.
-
-
Constructor Details
-
Vector
public Vector()Constructs a new vector using the default capacity. -
Vector
public Vector(int capacity)Constructs a new vector using the specified capacity.- Parameters:
capacity- the initial capacity of the new vector.- Throws:
IllegalArgumentException- ifcapacityis negative.
-
Vector
public Vector(int capacity, int capacityIncrement)Constructs a new vector using the specified capacity and capacity increment.- Parameters:
capacity- the initial capacity of the new vector.capacityIncrement- the amount to increase the capacity when this vector is full.- Throws:
IllegalArgumentException- ifcapacityis negative.
-
Vector
Constructs a new instance ofVectorcontaining the elements incollection. The order of the elements in the newVectoris dependent on the iteration order of the seed collection.- Parameters:
collection- the collection of elements to add.
-
-
Method Details
-
add
Adds the specified object into this vector at the specified location. The object is inserted before any element with the same or a higher index increasing their index by 1. If the location is equal to the size of this vector, the object is added at the end.- Specified by:
addin interfaceList<E>- Overrides:
addin classAbstractList<E>- Parameters:
location- the index at which to insert the element.object- the object to insert in this vector.- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location > size().- See Also:
addElement(E),size()
-
add
Adds the specified object at the end of this vector.- Specified by:
addin interfaceCollection<E>- Specified by:
addin interfaceList<E>- Overrides:
addin classAbstractList<E>- Parameters:
object- the object to add to the vector.- Returns:
true
-
addAll
Inserts the objects in the specified collection at the specified location in this vector. The objects are inserted in the order in which they are returned from the Collection iterator. The elements with an index equal or higher thanlocationhave their index increased by the size of the added collection.- Specified by:
addAllin interfaceList<E>- Overrides:
addAllin classAbstractList<E>- Parameters:
location- the location to insert the objects.collection- the collection of objects.- Returns:
trueif this vector is modified,falseotherwise.- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0orlocation > size().
-
addAll
Adds the objects in the specified collection to the end of this vector.- Specified by:
addAllin interfaceCollection<E>- Specified by:
addAllin interfaceList<E>- Overrides:
addAllin classAbstractCollection<E>- Parameters:
collection- the collection of objects.- Returns:
trueif this vector is modified,falseotherwise.
-
addElement
Adds the specified object at the end of this vector.- Parameters:
object- the object to add to the vector.
-
capacity
public int capacity()Returns the number of elements this vector can hold without growing.- Returns:
- the capacity of this vector.
- See Also:
ensureCapacity(int),size()
-
clear
public void clear()Removes all elements from this vector, leaving it empty. -
clone
Returns a new vector with the same elements, size, capacity and capacity increment as this vector. -
contains
Searches this vector for the specified object.- Specified by:
containsin interfaceCollection<E>- Specified by:
containsin interfaceList<E>- Overrides:
containsin classAbstractCollection<E>- Parameters:
object- the object to look for in this vector.- Returns:
trueif object is an element of this vector,falseotherwise.- See Also:
indexOf(Object),indexOf(Object, int),Object.equals(java.lang.Object)
-
containsAll
Searches this vector for all objects in the specified collection.- Specified by:
containsAllin interfaceCollection<E>- Specified by:
containsAllin interfaceList<E>- Overrides:
containsAllin classAbstractCollection<E>- Parameters:
collection- the collection of objects.- Returns:
trueif all objects in the specified collection are elements of this vector,falseotherwise.
-
copyInto
Attempts to copy elements contained by thisVectorinto the corresponding elements of the suppliedObjectarray.- Parameters:
elements- theObjectarray into which the elements of this vector are copied.- Throws:
IndexOutOfBoundsException- ifelementsis not big enough.- See Also:
clone()
-
elementAt
Returns the element at the specified location in this vector.- Parameters:
location- the index of the element to return in this vector.- Returns:
- the element at the specified location.
- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location >= size().- See Also:
size()
-
elements
Returns an enumeration on the elements of this vector. The results of the enumeration may be affected if the contents of this vector is modified.- Returns:
- an enumeration of the elements of this vector.
- See Also:
elementAt(int),Enumeration
-
ensureCapacity
public void ensureCapacity(int minimumCapacity)Ensures that this vector can hold the specified number of elements without growing.- Parameters:
minimumCapacity- the minimum number of elements that this vector will hold before growing.- See Also:
capacity()
-
equals
Compares the specified object to this vector and returns if they are equal. The object must be a List which contains the same objects in the same order.- Specified by:
equalsin interfaceCollection<E>- Specified by:
equalsin interfaceList<E>- Overrides:
equalsin classAbstractList<E>- Parameters:
object- the object to compare with this object- Returns:
trueif the specified object is equal to this vector,falseotherwise.- See Also:
hashCode()
-
firstElement
Returns the first element in this vector.- Returns:
- the element at the first position.
- Throws:
NoSuchElementException- if this vector is empty.- See Also:
elementAt(int),lastElement(),size()
-
get
Returns the element at the specified location in this vector.- Specified by:
getin interfaceList<E>- Specified by:
getin classAbstractList<E>- Parameters:
location- the index of the element to return in this vector.- Returns:
- the element at the specified location.
- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location >= size().- See Also:
size()
-
hashCode
public int hashCode()Returns an integer hash code for the receiver. Objects which are equal return the same value for this method.- Specified by:
hashCodein interfaceCollection<E>- Specified by:
hashCodein interfaceList<E>- Overrides:
hashCodein classAbstractList<E>- Returns:
- the receiver's hash.
- See Also:
equals(java.lang.Object)
-
indexOf
Searches in this vector for the index of the specified object. The search for the object starts at the beginning and moves towards the end of this vector.- Specified by:
indexOfin interfaceList<E>- Overrides:
indexOfin classAbstractList<E>- Parameters:
object- the object to find in this vector.- Returns:
- the index in this vector of the specified element, -1 if the element isn't found.
- See Also:
contains(java.lang.Object),lastIndexOf(Object),lastIndexOf(Object, int)
-
indexOf
Searches in this vector for the index of the specified object. The search for the object starts at the specified location and moves towards the end of this vector.- Parameters:
object- the object to find in this vector.location- the index at which to start searching.- Returns:
- the index in this vector of the specified element, -1 if the element isn't found.
- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0.- See Also:
contains(java.lang.Object),lastIndexOf(Object),lastIndexOf(Object, int)
-
insertElementAt
Inserts the specified object into this vector at the specified location. This object is inserted before any previous element at the specified location. All elements with an index equal or greater thanlocationhave their index increased by 1. If the location is equal to the size of this vector, the object is added at the end.- Parameters:
object- the object to insert in this vector.location- the index at which to insert the element.- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location > size().- See Also:
addElement(E),size()
-
isEmpty
public boolean isEmpty()Returns if this vector has no elements, a size of zero.- Specified by:
isEmptyin interfaceCollection<E>- Specified by:
isEmptyin interfaceList<E>- Overrides:
isEmptyin classAbstractCollection<E>- Returns:
trueif this vector has no elements,falseotherwise.- See Also:
size()
-
lastElement
Returns the last element in this vector.- Returns:
- the element at the last position.
- Throws:
NoSuchElementException- if this vector is empty.- See Also:
elementAt(int),firstElement(),size()
-
lastIndexOf
Searches in this vector for the index of the specified object. The search for the object starts at the end and moves towards the start of this vector.- Specified by:
lastIndexOfin interfaceList<E>- Overrides:
lastIndexOfin classAbstractList<E>- Parameters:
object- the object to find in this vector.- Returns:
- the index in this vector of the specified element, -1 if the element isn't found.
- See Also:
contains(java.lang.Object),indexOf(Object),indexOf(Object, int)
-
lastIndexOf
Searches in this vector for the index of the specified object. The search for the object starts at the specified location and moves towards the start of this vector.- Parameters:
object- the object to find in this vector.location- the index at which to start searching.- Returns:
- the index in this vector of the specified element, -1 if the element isn't found.
- Throws:
ArrayIndexOutOfBoundsException- iflocation >= size().- See Also:
contains(java.lang.Object),indexOf(Object),indexOf(Object, int)
-
remove
Removes the object at the specified location from this vector. All elements with an index bigger thanlocationhave their index decreased by 1.- Specified by:
removein interfaceList<E>- Overrides:
removein classAbstractList<E>- Parameters:
location- the index of the object to remove.- Returns:
- the removed object.
- Throws:
IndexOutOfBoundsException- iflocation < 0 || location >= size().
-
remove
Removes the first occurrence, starting at the beginning and moving towards the end, of the specified object from this vector. All elements with an index bigger than the element that gets removed have their index decreased by 1.- Specified by:
removein interfaceCollection<E>- Specified by:
removein interfaceList<E>- Overrides:
removein classAbstractCollection<E>- Parameters:
object- the object to remove from this vector.- Returns:
trueif the specified object was found,falseotherwise.- See Also:
removeAllElements(),removeElementAt(int),size()
-
removeAll
Removes all occurrences in this vector of each object in the specified Collection.- Specified by:
removeAllin interfaceCollection<E>- Specified by:
removeAllin interfaceList<E>- Overrides:
removeAllin classAbstractCollection<E>- Parameters:
collection- the collection of objects to remove.- Returns:
trueif this vector is modified,falseotherwise.- See Also:
remove(Object),contains(Object)
-
removeAllElements
public void removeAllElements()Removes all elements from this vector, leaving the size zero and the capacity unchanged. -
removeElement
Removes the first occurrence, starting at the beginning and moving towards the end, of the specified object from this vector. All elements with an index bigger than the element that gets removed have their index decreased by 1.- Parameters:
object- the object to remove from this vector.- Returns:
trueif the specified object was found,falseotherwise.- See Also:
removeAllElements(),removeElementAt(int),size()
-
removeElementAt
public void removeElementAt(int location)Removes the element found at index positionlocationfrom thisVector. All elements with an index bigger thanlocationhave their index decreased by 1.- Parameters:
location- the index of the element to remove.- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location >= size().- See Also:
removeElement(java.lang.Object),removeAllElements(),size()
-
removeRange
protected void removeRange(int start, int end)Removes the objects in the specified range from the start to the, but not including, end index. All elements with an index bigger than or equal toendhave their index decreased byend - start.- Overrides:
removeRangein classAbstractList<E>- Parameters:
start- the index at which to start removing.end- the index one past the end of the range to remove.- Throws:
IndexOutOfBoundsException- ifstart < 0, start > endorend > size().
-
retainAll
Removes all objects from this vector that are not contained in the specified collection.- Specified by:
retainAllin interfaceCollection<E>- Specified by:
retainAllin interfaceList<E>- Overrides:
retainAllin classAbstractCollection<E>- Parameters:
collection- the collection of objects to retain.- Returns:
trueif this vector is modified,falseotherwise.- See Also:
remove(Object)
-
set
Replaces the element at the specified location in this vector with the specified object.- Specified by:
setin interfaceList<E>- Overrides:
setin classAbstractList<E>- Parameters:
location- the index at which to put the specified object.object- the object to add to this vector.- Returns:
- the previous element at the location.
- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location >= size().- See Also:
size()
-
setElementAt
Replaces the element at the specified location in this vector with the specified object.- Parameters:
object- the object to add to this vector.location- the index at which to put the specified object.- Throws:
ArrayIndexOutOfBoundsException- iflocation < 0 || location >= size().- See Also:
size()
-
setSize
public void setSize(int length)Sets the size of this vector to the specified size. If there are more than length elements in this vector, the elements at end are lost. If there are less than length elements in the vector, the additional elements contain null.- Parameters:
length- the new size of this vector.- See Also:
size()
-
size
public int size()Returns the number of elements in this vector.- Specified by:
sizein interfaceCollection<E>- Specified by:
sizein interfaceList<E>- Specified by:
sizein classAbstractCollection<E>- Returns:
- the number of elements in this vector.
- See Also:
elementCount,lastElement()
-
subList
Returns a List of the specified portion of this vector from the start index to one less than the end index. The returned List is backed by this vector so changes to one are reflected by the other.- Specified by:
subListin interfaceList<E>- Overrides:
subListin classAbstractList<E>- Parameters:
start- the index at which to start the sublist.end- the index one past the end of the sublist.- Returns:
- a List of a portion of this vector.
- Throws:
IndexOutOfBoundsException- ifstart < 0orend > size().IllegalArgumentException- ifstart > end.
-
toArray
Returns a new array containing all elements contained in this vector.- Specified by:
toArrayin interfaceCollection<E>- Specified by:
toArrayin interfaceList<E>- Overrides:
toArrayin classAbstractCollection<E>- Returns:
- an array of the elements from this vector.
-
toArray
public <T> T[] toArray(T[] contents)Returns an array containing all elements contained in this vector. If the specified array is large enough to hold the elements, the specified array is used, otherwise an array of the same type is created. If the specified array is used and is larger than this vector, the array element following the collection elements is set to null.- Specified by:
toArrayin interfaceCollection<E>- Specified by:
toArrayin interfaceList<E>- Overrides:
toArrayin classAbstractCollection<E>- Parameters:
contents- the array to fill.- Returns:
- an array of the elements from this vector.
- Throws:
ArrayStoreException- if the type of an element in this vector cannot be stored in the type of the specified array.
-
toString
Returns the string representation of this vector.- Overrides:
toStringin classAbstractCollection<E>- Returns:
- the string representation of this vector.
- See Also:
elements()
-
trimToSize
public void trimToSize()Sets the capacity of this vector to be the same as the size.- See Also:
capacity(),ensureCapacity(int),size()
-