java數組和list區別
① java list 和數組的區別
list可以裝對象,不限制大小,順序排序,可以不用類型。
數組必須相同類型。
② java 中數組和集合的區別
1、數組特點高效、保存基本類型,集合帶array的底層由數組實現,還有一部分由鏈表或者樹 2、數組大小固定(巨大缺點,內存中一定連續),集合各種實現吧! 3、數組只能放一種類型,集合不考慮泛型可以存很多類型。
③ Java面試題:數組和列表有什麼區別
兩者差別:
如果為數組分配100個元素的存儲空間,那麼數組就有了100個空位置可以使用。而容量為100
個元素的數組列表擁有保存100個元素的潛力(實際上,重新分配空間的話,將會超過100個)
但是在最初,甚至完成初始化建造之後,數組列表根本就不含有任何元素。
創建數組是需要指定大小,不適合於用在動態變動的情況;使用數組列表的一點缺陷是不能用下標訪問
Java數組教程:
④ java里的數組和list分別在什麼情況下使用
數組長度固定,List未限定長度,且支持的功能更多,最常用的ArrayList底層實際上也是使用數組實現。不需要復雜功能和確定長度的情況下,使用數組效率更高,通常情況建議使用List。
⑤ java arraylist和數組的區別
簡單點說。list用起來更方便,不管取數據還是放數據。
⑥ java中隊列,數組和list集合的區別
數組是JAVA語言內置的數據類型,它是一個線性的序列,所以它可以快速的訪問其他的元素。但是速度是要有代價的燃純,當你創建了一個數組之後,它的容量就固定了,而且在其生命周期里是不能改變的。還有一點,JAVA裡面的數組是會做邊界檢查的,所以當你越界訪問時,會拋出RuntimeException,所以不用擔心在C或C++因為不做邊界檢查而出現的問題了,當然邊界檢查是以犧牲效率為代價的。數組與其它容器類的區別體現在三個方面:效率、類型識別和可以持有primitives。 JAVA裡面提供的其他容器還包括List,Set和神段桐Map。他們處理對象的時候就好像這些這些對象都沒有自己的類型一樣,容器將它所含的元素都看成是JAVA中所有類的根類Object類型的,這樣我們只需創建一種容器,就能把所有的類型的對象全部放進去。但是當取出的時候,那就需要我們自己進行類型轉換了,不過在JAVA Tiger版裡面新引入了「泛型」的概念,結合容器類一起使用就可以解游坦決類型轉換的問題,關於「泛型」這就不詳細講解了。從上面的角度來看,這種做法很不錯,但是就是苦了primitives,如果是常量的話,可以把primitive轉換成wrapper類然後放進容器裡面,如果是變數的話,那就只能放在你自己的類里了。與其他容器類相比,數組會在編譯的時候作類型檢查,從而防止你插入錯誤類型的對象,或者在提取對象的時候把對象的類型給搞錯了,JAVA在編譯和運行的時候都能阻止你將一個不恰當的消息傳給對象。至於效率,數組無疑是要高於其他容器類的,因為有些容器類的實現就是基於數組的,比如ArrayList。不論從類型檢查還是效率的角度來考慮,我們首選數組來作為容器都是沒錯的,但是數組的缺點就是功能太弱了,所以才會有容器類的出現。 要多說幾句的就是,java.util包裡面有一個Arrays類,它包括了一組可以用於數組的static的工具方法,其中最基本的是四個方法:用來比較兩個數組是否相等的equals();用來填充數組的fill();用來對數組進行排序的sort();以及用於在一個已經排序的數組中查找元素的binarySearch()。所有這些方法都對primitives和Object進行了重載。此外還有一個asList()方法,它接受一個數組,然後把它轉成一個List容器。JAVA標准類庫還提供了一個System.array()的靜態方法,它能以較快的速度拷貝數組,對primitive和Object都進行了重載,但是注意當對Object數組進行拷貝時,進行的是淺拷貝(shallow )
⑦ java list和數組的區別
看看這個吧
ArrayList 和Vector都是使用數缺櫻組方式存儲數據,此數組元素數大於實際存儲的數據以便增加和插入元素,它們都允許直伏褲叢接純旅按序號索引元素,但是插入元素要涉及數組元素移動等內存操作,所以索引數據快而插入數據慢,Vector由於使用了synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實現存儲,按序號索引數據需要進行前向或後向遍歷,但是插入數據時只需要記錄本項的前後項即可,所以插入速度較快。