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