欧美成人午夜免费全部完,亚洲午夜福利精品久久,а√最新版在线天堂,另类亚洲综合区图片小说区,亚洲欧美日韩精品色xxx

扣丁學(xué)堂為您講解Java靜態(tài)與動態(tài)數(shù)組特點分析

2018-01-05 11:28:54 1183瀏覽

       在JAVA編程界中,我們接觸到的大多都是靜態(tài)數(shù)組,其實在很多的時候,靜態(tài)數(shù)組根本不能滿足我們編程的實際需要,比方說我需要在程序運行過程中動態(tài)的向數(shù)組中添加數(shù)據(jù),這時我們的靜態(tài)數(shù)組大小是固定的,顯然就不能添加數(shù)據(jù),要動態(tài)添加數(shù)據(jù)必須要用到動態(tài)數(shù)組,動態(tài)數(shù)組中的各個元素類型也是一致的,不過這種類型已經(jīng)是用一個非常大的類型來攬括-Object類型。Object類是JAVA.LANG包中的頂層超類。所有的類型都可以與Object類型兼容,所以我們可以將任何Object類型添加至屬于Object類型的數(shù)組中,能添加Object類型的的集合有ArrayList、Vector及LinkedList,它們對數(shù)據(jù)的存放形式仿造于數(shù)組,屬于集合類,下面是他們的特點:



        1、同步性

        ArrayList,LinkedList是不同步的,而Vestor是的。所以如果要求線程安全的話,可以使用ArrayList或LinkedList,可以節(jié)省為同步而耗費開銷。但在多線程的情況下,有時候就不得不使用Vector了。當(dāng)然,也可以通過一些辦法包裝ArrayList,LinkedList,使他們也達(dá)到同步,但效率可能會有所降低。

        2、數(shù)據(jù)操作效率

       ArrayList和Vector中,從指定的位置(用index)檢索一個對象,或在集合的末尾插入、刪除一個對象的時間是一樣的,可表示為O(1)。但是,如果在集合的其他位置增加或移除元素那么花費的時間會呈線形增長:O(n-i),其中n代表集合中元素的個數(shù),i代表元素增加或移除元素的索引位置。為什么會這樣呢?以為在進(jìn)行上述操作的時候集合中第i和第i個元素之后的所有元素都要執(zhí)行(n-i)個對象的位移操作。LinkedList中,在插入、刪除集合中任何位置的元素所花費的時間都是一樣的-O(1),但它在索引一個元素的時候比較慢,為O(i),其中i是索引的位置。

       3、容量擴(kuò)充性

       從內(nèi)部實現(xiàn)機(jī)制來講ArrayList和Vector都是使用Objec的數(shù)組形式來存儲的。當(dāng)你向這兩種類型中增加元素的時候,如果元素的數(shù)目超出了內(nèi)部數(shù)組目前的長度它們都需要擴(kuò)展內(nèi)部數(shù)組的長度,Vector缺省情況下自動增長原來一倍的數(shù)組長度,ArrayList是原來的50%,所以最后你獲得的這個集合所占的空間總是比你實際需要的要大。所以如果你要在集合中保存大量的數(shù)據(jù)那么使用Vector有一些優(yōu)勢,因為你可以通過設(shè)置集合的初始化大小來避免不必要的資源開銷。

       所以,如果只是查找特定位置的元素或只在集合的末端增加、移除元素,那么使用Vector或ArrayList都可以。如果是對其它指定位置的插入、刪除操作,最好選擇LinkedListArrayList和Vector是采用數(shù)組方式存儲數(shù)據(jù),此數(shù)組元素數(shù)大于實際存儲的數(shù)據(jù)以便增加和插入元素,都允許直接序號索引元素,但是插入數(shù)據(jù)要設(shè)計到數(shù)組元素移動等內(nèi)存操作,所以索引數(shù)據(jù)快插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實現(xiàn)存儲,按序號索引數(shù)據(jù)需要進(jìn)行向前或向后遍歷,但是插入數(shù)據(jù)時只需要記錄本項的前后項即可,所以插入數(shù)度較快。


       以上就是扣丁學(xué)堂關(guān)于JAVA靜態(tài)與動態(tài)數(shù)組分析,想要學(xué)好Java就一定要選擇專業(yè)的靠譜的培訓(xùn)機(jī)構(gòu),扣丁學(xué)堂Java培訓(xùn)不僅有專業(yè)的老師授課,還有緊隨時代發(fā)展與時俱進(jìn)的課程體系供學(xué)員學(xué)習(xí),更有大量的Java視頻教程讓學(xué)員免費觀看,想要學(xué)好Java的小伙伴們,扣丁學(xué)堂絕對是你學(xué)習(xí)的最佳之地,想要學(xué)好Java高薪就業(yè)的話就抓緊時間行動吧。Java技術(shù)交流群:670348138。

關(guān)注微信公眾號獲取更多的學(xué)習(xí)資料



查看更多關(guān)于“Java開發(fā)資訊的相關(guān)文章>>



標(biāo)簽: JAVA培訓(xùn) JAVA視頻教程 JAVA開發(fā)工程師

熱門專區(qū)

暫無熱門資訊

課程推薦

微信
微博
15311698296

全國免費咨詢熱線

郵箱:codingke@1000phone.com

官方群:148715490

北京千鋒互聯(lián)科技有限公司版權(quán)所有   北京市海淀區(qū)寶盛北里西區(qū)28號中關(guān)村智誠科創(chuàng)大廈4層
京ICP備2021002079號-2   Copyright ? 2017 - 2022
返回頂部 返回頂部