詳解Java編程中向量(Vector)的應(yīng)用
Vector(向量)是 java.util 包中的一個(gè)類,該類實(shí)現(xiàn)了類似動(dòng)態(tài)數(shù)組的功能。
向量和數(shù)組相似,都可以保存一組數(shù)據(jù)(數(shù)據(jù)列表)。但是數(shù)組的大小是固定的,一旦指定,就不能改變,而向量卻提供了一種類似于“動(dòng)態(tài)數(shù)組”的功能,向量與數(shù)組的重要區(qū)別之一就是向量的容量是可變的。
可以在向量的任意位置插入不同類型的對(duì)象,無(wú)需考慮對(duì)象的類型,也無(wú)需考慮向量的容量。
向量和數(shù)組分別適用于不同的場(chǎng)合,一般來(lái)說(shuō),下列場(chǎng)合更適合于使用向量:
如果需要頻繁進(jìn)行對(duì)象的插入和刪除工作,或者因?yàn)樾枰幚淼膶?duì)象數(shù)目不定。
列表成員全部都是對(duì)象,或者可以方便的用對(duì)象表示。
需要很快確定列表內(nèi)是否存在某一特定對(duì)象,并且希望很快了解到對(duì)象的存放位置。
向量作為一種對(duì)象提供了比數(shù)組更多的方法,但需要注意的是,向量只能存儲(chǔ)對(duì)象,不能直接存儲(chǔ)簡(jiǎn)單數(shù)據(jù)類型,因此下列場(chǎng)合適用于使用數(shù)組:
- 所需處理的對(duì)象數(shù)目大致可以確定。
- 所需處理的是簡(jiǎn)單數(shù)據(jù)類型。
向量的使用
向量必須要先創(chuàng)建后使用,向量的大小是向量中元素的個(gè)數(shù),向量的容量是被分配用來(lái)存儲(chǔ)元素的內(nèi)存大小,其大小總是大于向量的大小。下面是 Vector 的構(gòu)造方法:
Vector(); //①創(chuàng)建空向量,初始大小為 10 Vector(int initialCapacity); //②創(chuàng)建初始容量為 capacity 的空向量 Vector(int initialCapacity,int capacityIncrement); //③創(chuàng)建初始容量為 initialCapacity,增量為 capacityIncrement 的空向量
使用第①種方式系統(tǒng)會(huì)自動(dòng)對(duì)向量進(jìn)行管理。
使用第②種方式,會(huì)創(chuàng)建一個(gè)初始容量(即向量可存儲(chǔ)數(shù)據(jù)的大小)為 initialCapacity 的空向量,當(dāng)真正存放的數(shù)據(jù)超過(guò)該容量時(shí),系統(tǒng)會(huì)自動(dòng)擴(kuò)充容量,每次增加一倍。
使用第③中方式,會(huì)創(chuàng)建一個(gè)初始容量為 initialCapacity 的空向量,當(dāng)真正存放的數(shù)據(jù)超過(guò)該容量時(shí),系統(tǒng)每次會(huì)自動(dòng)擴(kuò)充 capacityIncrement。如果 capacityIncrement 為0,那么每次增加一倍,。
通過(guò)分配多于所需的內(nèi)存空間,向量減少了必須的內(nèi)存分配的數(shù)目。這樣能夠有效地減少分配所消耗的時(shí)間,每次分配的額外空間數(shù)目將由創(chuàng)建向量時(shí)指定的增量所決定。
除了構(gòu)造方法外,向量類還提供了三個(gè)屬性變量,分別為:
protected int capacityIncrement; //當(dāng)向量大小不足時(shí),所用的增量大小 protected int elementCount; //向量的元素個(gè)數(shù) protected Object elementData[]; //向量成員數(shù)據(jù)所用的緩沖
一旦創(chuàng)建了Vector類的實(shí)例,就可以用其方法來(lái)執(zhí)行插入、刪除以及查找對(duì)象等操作,向量類提供了極為豐富的方法,下表給出了一些常用的方法:


與數(shù)組相同,向量對(duì)象也可以通過(guò) new 操作符實(shí)現(xiàn)。其語(yǔ)句為:
Vector vector=new Vector();
相關(guān)文章
Java中的CopyOnWriteArrayList容器解析
這篇文章主要介紹了Java中的CopyOnWriteArrayList容器解析,CopyOnWriteArrayList容器允許并發(fā)讀,讀操作是無(wú)鎖的,性能較高。至于寫操作,比如向容器中添加一個(gè)元素,則首先將當(dāng)前容器復(fù)制一份,然后在新副本上執(zhí)行寫操作,需要的朋友可以參考下2023-12-12
Mybatis返回結(jié)果封裝map過(guò)程解析
這篇文章主要介紹了Mybatis返回結(jié)果封裝map過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
SpringBoot生產(chǎn)環(huán)境打包如何去除無(wú)用依賴
這篇文章主要介紹了SpringBoot生產(chǎn)環(huán)境打包如何去除無(wú)用依賴問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
如何使用Spring Security手動(dòng)驗(yàn)證用戶的方法示例
這篇文章主要介紹了如何使用Spring Security手動(dòng)驗(yàn)證用戶的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05
使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法
這篇文章主要介紹了使用socket進(jìn)行服務(wù)端與客戶端傳文件的方法,需要的朋友可以參考下2017-08-08
Java異步線程中的CompletableFuture與@Async詳解
這篇文章主要介紹了Java異步線程中的CompletableFuture與@Async詳解,CompletableFuture是java中提供的一個(gè)異步執(zhí)行類,@Async是Spring提供的異步執(zhí)行方法,當(dāng)調(diào)用方法單獨(dú)開啟一個(gè)線程進(jìn)行調(diào)用,需要的朋友可以參考下2024-01-01

