麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Java > 正文

JAVA中靜態數組與動態數組

2024-07-14 08:44:03
字體:
來源:轉載
供稿:網友

  前面我們學習的數組都是靜態數組,其實在很多的時候,靜態數組根本不能滿足我們編程的實際需要,比方說我需要在程序運行過程中動態的向數組中添加數據,這時我們的靜態數組大小是固定的,顯然就不能添加數據,要動態添加數據必須要用到動態數組,動態數組中的各個元素類型也是一致的,不過這種類型已經是用一個非常大的類型來攬括—Object類型。

  Object類是JAVA.LANG包中的頂層超類。所有的類型都可以與Object類型兼容,所以我們可以將任何Object類型添加至屬于Object類型的數組中,能添加Object類型的的集合有ArrayList、Vector及LinkedList,它們對數據的存放形式仿造于數組,屬于集合類,下面是他們的特點:

  特點一、容量擴充性

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

  特點二、同步性

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

  特點三、數據操作效率

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

  LinkedList中,在插入、刪除集合中任何位置的元素所花費的時間都是一樣的—O(1),但它在索引一個元素的時候比較慢,為O(i),其中i是索引的位置。

  所以,如果只是查找特定位置的元素或只在集合的末端增加、移除元素,那么使用Vector或ArrayList都可以。如果是對其它指定位置的插入、刪除操作,最好選擇LinkedList

  ArrayList 和Vector是采用數組方式存儲數據,此數組元素數大于實際存儲的數據以便增加和插入元素,都允許直接序號索引元素,但是插入數據要設計到數組元素移動等內存操作,所以索引數據快插入數據慢,Vector由于使用了synchronized方法(線程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實現存儲,按序號索引數據需要進行向前或向后遍歷,但是插入數據時只需要記錄本項的前后項即可,所以插入數度較快。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美在线观看视频网站 | 欧美久久久一区二区三区 | av在线免费看网站 | 一色桃子av大全在线播放 | 一级免费在线视频 | 羞羞视频免费视频欧美 | 亚洲成人自拍电影 | 欧美激情精品久久久久久黑人 | 精品国产一区二区久久 | 欧美日韩在线免费观看 | 蜜桃网在线观看 | 黄色影院在线观看视频 | 亚洲国产超高清a毛毛片 | 精品国产91一区二区三区 | 国产精品久久久久久久四虎电影 | 性aaa| 亚洲成在人| 91午夜少妇三级全黄 | 免费亚洲视频在线观看 | 日韩欧美视频一区二区三区 | 久色精品视频 | 成人毛片免费在线 | 一本色道久久综合亚洲精品图片 | 成人免费电影在线观看 | 涩涩屋av| 国产精品免费小视频 | 国产一区二区三区欧美 | 深夜福利视频免费观看 | 九九热免费观看 | 99精品热视频 | 久久17| 日本精品一二区 | 成人在线视频免费看 | 国产99久久久久久免费看 | 国产一区二区免费在线观看 | 中文字幕亚洲一区二区三区 | 免费在线观看一级片 | 五月婷婷第四色 | 国产精品久久亚洲 | 亚洲国产高清一区 | 国产一级aa大片毛片 |