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