在java提高篇(二一)—–ArrayList、java提高篇(二二)—LinkedList,詳細講解了ArrayList、linkedList的原理和實現過程,對于List接口這里還介紹一個它的實現類Vector,Vector 類可以實現可增長的對象數組。
Vector可以實現可增長的對象數組。與數組一樣,它包含可以使用整數索引進行訪問的組件。不過,Vector的大小是可以增加或者減小的,以便適應創建Vector后進行添加或者刪除操作。
Vector實現List接口,繼承AbstractList類,所以我們可以將其看做隊列,支持相關的添加、刪除、修改、遍歷等功能。
Vector實現Randmoaccess接口,即提供了隨機訪問功能,提供提供快速訪問功能。在Vector我們可以直接訪問元素。
Vector 實現了Cloneable接口,支持clone()方法,可以被克隆。
[java] view plain copyVector提供了四個構造函數:
[java] view%20plain copy在成員變量方面,Vector提供了elementData%20,%20elementCount,%20capacityIncrement三個成員變量。其中
elementData%20:"Object[]類型的數組",它保存了Vector中的元素。按照Vector的設計elementData為一個動態數組,可以隨著元素的增加而動態的增長,其具體的增加方式后面提到(ensureCapacity方法)。如果在初始化Vector時沒有指定容器大小,則使用默認大小為10.
elementCount:Vector
對象中的有效組件數。
capacityIncrement:向量的大小大于其容量時,容量自動增加的量。如果在創建Vector時,指定了capacityIncrement的大小;則,每次當Vector中動態數組容量增加時>,增加的大小都是capacityIncrement。如果容量的增量小于等于零,則每次需要增大容量時,向量的容量將增大一倍。
同時Vector是線程安全的!
這個方法相對而言比較簡單,具體過程就是先確認容器的大小,看是否需要進行擴容操作,然后將E元素添加到此向量的末尾。
[java] view%20plain copy因為Vector底層是使用數組實現的,所以它的操作都是對數組進行操作,只不過其是可以隨著元素的增加而動態的改變容量大小,其實現方法是是使用Arrays.copyOf方法將舊數據拷貝到一個新的大容量數組中。Vector的整個內部實現都比較簡單,這里就不在重述了。
Vector支持4種遍歷方式。
因為Vector實現了RandmoAccess接口,可以通過下標來進行隨機訪問。
[java] view%20plain copy新聞熱點
疑難解答