Java靜態(tài)與動(dòng)態(tài)數組特點(diǎn)分析
在JAVA編程界中,我們接觸到的大多都是靜態(tài)數組,其實(shí)在很多的時(shí)候,靜態(tài)數組根本不能滿(mǎn)足我們編程的實(shí)際需要,比方說(shuō)我需要在程序運行過(guò)程中動(dòng)態(tài)的向數組中添加數據,這時(shí)我們的靜態(tài)數組大小是固定的,顯然就不能添加數據,要動(dòng)態(tài)添加數據必須要用到動(dòng)態(tài)數組,動(dòng)態(tài)數組中的各個(gè)元素類(lèi)型也是一致的,不過(guò)這種類(lèi)型已經(jīng)是用一個(gè)非常大的類(lèi)型來(lái)攬括-Object類(lèi)型。Object類(lèi)是JAVA.LANG包中的頂層超類(lèi)。所有的類(lèi)型都可以與Object類(lèi)型兼容,所以我們可以將任何Object類(lèi)型添加至屬于Object類(lèi)型的數組中,能添加Object類(lèi)型的的集合有ArrayList、Vector及LinkedList,它們對數據的存放形式仿造于數組,屬于集合類(lèi),下面是他們的特點(diǎn):
1、同步性
ArrayList,LinkedList是不同步的,而Vestor是的。所以如果要求線(xiàn)程安全的話(huà),可以使用ArrayList或LinkedList,可以節省為同步而耗費開(kāi)銷(xiāo)。但在多線(xiàn)程的情況下,有時(shí)候就不得不使用Vector了。當然,也可以通過(guò)一些辦法包裝ArrayList,LinkedList,使他們也達到同步,但效率可能會(huì )有所降低。
2、數據操作效率
ArrayList和Vector中,從指定的位置(用index)檢索一個(gè)對象,或在集合的末尾插入、刪除一個(gè)對象的時(shí)間是一樣的,可表示為O(1)。但是,如果在集合的其他位置增加或移除元素那么花費的時(shí)間會(huì )呈線(xiàn)形增長(cháng):O(n-i),其中n代表集合中元素的個(gè)數,i代表元素增加或移除元素的索引位置。為什么會(huì )這樣呢?以為在進(jìn)行上述操作的時(shí)候集合中第i和第i個(gè)元素之后的所有元素都要執行(n-i)個(gè)對象的位移操作。LinkedList中,在插入、刪除集合中任何位置的元素所花費的時(shí)間都是一樣的-O(1),但它在索引一個(gè)元素的時(shí)候比較慢,為O(i),其中i是索引的位置。
3、容量擴充性
從內部實(shí)現機制來(lái)講ArrayList和Vector都是使用Objec的數組形式來(lái)存儲的。當你向這兩種類(lèi)型中增加元素的時(shí)候,如果元素的數目超出了內部數組目前的長(cháng)度它們都需要擴展內部數組的長(cháng)度,Vector缺省情況下自動(dòng)增長(cháng)原來(lái)一倍的數組長(cháng)度,ArrayList是原來(lái)的50%,所以最后你獲得的這個(gè)集合所占的空間總是比你實(shí)際需要的要大。所以如果你要在集合中保存大量的數據那么使用Vector有一些優(yōu)勢,因為你可以通過(guò)設置集合的初始化大小來(lái)避免不必要的資源開(kāi)銷(xiāo)。
所以,如果只是查找特定位置的元素或只在集合的末端增加、移除元素,那么使用Vector或ArrayList都可以。如果是對其它指定位置的插入、刪除操作,最好選擇LinkedListArrayList和Vector是采用數組方式存儲數據,此數組元素數大于實(shí)際存儲的數據以便增加和插入元素,都允許直接序號索引元素,但是插入數據要設計到數組元素移動(dòng)等內存操作,所以索引數據快插入數據慢,Vector由于使用了synchronized方法(線(xiàn)程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實(shí)現存儲,按序號索引數據需要進(jìn)行向前或向后遍歷,但是插入數據時(shí)只需要記錄本項的前后項即可,所以插入數度較快。
以上就是扣丁學(xué)堂關(guān)于JAVA靜態(tài)與動(dòng)態(tài)數組分析,想要學(xué)好Java就一定要選擇專(zhuān)業(yè)的靠譜的培訓機構,扣丁學(xué)堂Java培訓不僅有專(zhuān)業(yè)的老師授課,還有緊隨時(shí)代發(fā)展與時(shí)俱進(jìn)的課程體系供學(xué)員學(xué)習,更有大量的Java視頻教程讓學(xué)員免費觀(guān)看,想要學(xué)好Java的小伙伴們,扣丁學(xué)堂絕對是你學(xué)習的最佳之地,想要學(xué)好Java高薪就業(yè)的話(huà)就抓緊時(shí)間行動(dòng)吧??鄱W(xué)堂Java技術(shù)交流群:850353792。
*博客內容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀(guān)點(diǎn),如有侵權請聯(lián)系工作人員刪除。