1)精辟闡述:
可以將 ArrayList想象成一種“會(huì)自動(dòng)擴(kuò)增容量的Array”。
2)Array([]):最高效;但是其容量固定且無(wú)法動(dòng)態(tài)改變;
ArrayList: 容量可動(dòng)態(tài)增長(zhǎng);但犧牲效率;
3)建議:
基于效率和類(lèi)型檢驗(yàn),應(yīng)盡可能使用Array,無(wú)法確定數(shù)組大小時(shí)才使用ArrayList!
不過(guò)當(dāng)你試著解決更一般化的問(wèn)題時(shí),Array的功能就可能過(guò)于受限。
4)Java中一切皆對(duì)象,Array也是對(duì)象。不論你所使用得Array型別為何,
Array名稱(chēng)本身實(shí)際上是個(gè)reference,指向heap之內(nèi)得某個(gè)實(shí)際對(duì)象。
這個(gè)對(duì)象可經(jīng)由“Array初始化語(yǔ)法”被自動(dòng)產(chǎn)生,也可以以new表達(dá)式手動(dòng)產(chǎn)生。
5)Array可做為函數(shù)返回值,因?yàn)樗旧硎菍?duì)象的reference;
6)對(duì)象數(shù)組與基本類(lèi)型數(shù)組在運(yùn)用上幾乎一模一樣,唯一差別在于,前者持有得是reference,后者直接持有基本型別之值;
例如:
1
2
|
string [] staff= new string[ 100 ]; int [] num= new int [ 10 ]; |
7)容器所持有的其實(shí)是一個(gè)個(gè)reference指向Object,進(jìn)而才能存儲(chǔ)任意型別。當(dāng)然這不包括基本型別,因?yàn)榛拘蛣e并不繼承自任何classes。
8)面對(duì)Array,我們可以直接持有基本型別數(shù)值的Array(例如:int [] num;),也可以持有reference(指向?qū)ο螅┑腁rray;但是容器類(lèi)僅能持有reference(指向?qū)ο螅粢獙⒒拘蛣e置于容器內(nèi),需要使用wrapper類(lèi)。但是wrapper類(lèi)使用起來(lái)可能不很容易上手,此外,primitives Array的效率比起“容納基本型別之外覆類(lèi)(的reference)”的容器好太多了。
當(dāng)然,如果你的操作對(duì)象是基本型別,而且需要在空間不足時(shí)自動(dòng)擴(kuò)增容量,Array便不適合,此時(shí)就得使用外覆類(lèi)的容器了。
9)某些情況下,容器類(lèi)即使沒(méi)有轉(zhuǎn)型至原來(lái)的型別,仍然可以運(yùn)作無(wú)誤。有一種情況尤其特別:編譯器對(duì)String class提供了一些額外的支持,使它可以平滑運(yùn)作。
10)對(duì)數(shù)組的一些基本操作,像排序、搜索與比較等是很常見(jiàn)的。因此在Java中提供了Arrays類(lèi)協(xié)助這幾個(gè)操作:sort(),binarySearch(),equals(),fill(),asList().
不過(guò)Arrays類(lèi)沒(méi)有提供刪除方法,而ArrayList中有remove()方法,不知道是否是不需要在Array中做刪除等操作的原因(因?yàn)榇藭r(shí)應(yīng)該使用鏈表)。
11)ArrayList的使用也很簡(jiǎn)單:產(chǎn)生ArrayList,利用add()將對(duì)象置入,利用get(i)配合索引值將它們?nèi)〕觥_@一切就和Array的使用方式完全相同,只不過(guò)少了[]而已。
2.參考資料:
1)效率:
數(shù)組擴(kuò)容是對(duì)ArrayList效率影響比較大的一個(gè)因素。
每當(dāng)執(zhí)行Add、AddRange、Insert、InsertRange等添加元素的方法,都會(huì)檢查內(nèi)部數(shù)組的容量是否不夠了,如果是,它就會(huì)以當(dāng)前容量的兩倍來(lái)重新構(gòu)建一個(gè)數(shù)組,將舊元素Copy到新數(shù)組中,然后丟棄舊數(shù)組,在這個(gè)臨界點(diǎn)的擴(kuò)容操作,應(yīng)該來(lái)說(shuō)是比較影響效率的。
ArrayList是Array的復(fù)雜版本
ArrayList內(nèi)部封裝了一個(gè)Object類(lèi)型的數(shù)組,從一般的意義來(lái)說(shuō),它和數(shù)組沒(méi)有本質(zhì)的差別,甚至于ArrayList的許多方法,如Index、IndexOf、Contains、Sort等都是在內(nèi)部數(shù)組的基礎(chǔ)上直接調(diào)用Array的對(duì)應(yīng)方法。
2)類(lèi)型識(shí)別:
ArrayList存入對(duì)象時(shí),拋棄類(lèi)型信息,所有對(duì)象屏蔽為Object,編譯時(shí)不檢查類(lèi)型,但是運(yùn)行時(shí)會(huì)報(bào)錯(cuò)。
ArrayList與數(shù)組的區(qū)別主要就是由于動(dòng)態(tài)增容的效率問(wèn)題了
3)ArrayList可以存任何Object,如String等。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!