Efficient Use of the Vector Class

Efficient Use of the Vector Class

The Vector class in java.util is one of the most frequently used classes in Java development. It almost makes the problem of memory management non-existent, unlike a fixed-size array. However, using this class doesn’t come without a cost. At instantiation, a Vector object allocates memory for 10 object references by default. This leads us to ask, “What happens when we add an 11th element to the vector?” Take a look at the following method for populating a Vector with 200 elements:

  1. public void vectorCapacity () {
  2. Vector v = new Vector();
  3. int capacity = v.capacity();
  4. int elementNo = 0;
  5. // Add 200 elements
  6. for (int i = 0; i v.addElement("FOO");
  7. // If capacity changes, print out new capacity
  8. if (capacity != v.capacity()) {
  9. capacity = v.capacity();
  10. System.out.println(i + "th element, Capacity = " +
  11. v.capacity());
  12. }
  13. }
  14. }

Calling this method produces the following output:

 10th element, Capacity = 2020th element, Capacity = 4040th element, Capacity = 8080th element, Capacity = 160160th element, Capacity = 320

When a Vector exceeds 10 objects, its capacity is increased by 10. The new capacity also defines the chunk of memory for the next aggregation. In other words, the capacity of a Vector doubles with each memory reallocation. In the example given above, the memory had to reallocate five times in order to store 200 elements.

You can avoid this problem by estimating in advance how many objects will be stored in the Vector. To increase the chunk of memory that gets allocated each time the Vector needs to increase its capacity. You can accomplish this by inserting the following between lines 3 and 4 in the code snippet above:


The output now shows:

 100th element, Capacity = 200

The number of memory reallocations is reduced to one instead of five. If you plan to use the Vector for a large number of objects, try to estimate the chunk of memory that you would want during each reallocation.


Share the Post: