成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java中靜態(tài)數(shù)組與動(dòng)態(tài)數(shù)組

開發(fā) 后端
我們學(xué)習(xí)的數(shù)組都是靜態(tài)數(shù)組,不過在Java的實(shí)際應(yīng)用中,更多的也會(huì)用到動(dòng)態(tài)數(shù)組。本文將為大家介紹Java中靜態(tài)數(shù)組與動(dòng)態(tài)數(shù)組。

我們學(xué)習(xí)的數(shù)組都是靜態(tài)數(shù)組,其實(shí)在很多的時(shí)候,靜態(tài)數(shù)組根本不能滿足我們編程的實(shí)際需要,比方說我需要在程序運(yùn)行過程中動(dòng)態(tài)的向數(shù)組中添加數(shù)據(jù),這時(shí)我們的靜態(tài)數(shù)組大小是固定的,顯然就不能添加數(shù)據(jù),要?jiǎng)討B(tài)添加數(shù)據(jù)必須要用到動(dòng)態(tài)數(shù)組,動(dòng)態(tài)數(shù)組中的各個(gè)元素類型也是一致的,不過這種類型已經(jīng)是用一個(gè)非常大的類型來攬括—Object類型。

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

特點(diǎn)一、容量擴(kuò)充性

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

特點(diǎn)二、同步性

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

特點(diǎn)三、數(shù)據(jù)操作效率

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

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

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

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

【編輯推薦】

  1. Java編譯器中對String對象的優(yōu)化
  2. Java語言中抽象類和接口的區(qū)別
  3. Java Swing開發(fā)中的線程安全
責(zé)任編輯:彭凡 來源: ITPUB論壇
相關(guān)推薦

2011-07-03 19:45:32

SEO

2011-06-08 14:42:33

C++多維數(shù)組

2024-08-30 08:43:24

JavaScriptforEachfor循環(huán)

2023-01-09 18:15:21

數(shù)組Python類型

2009-09-17 18:14:05

C#動(dòng)態(tài)數(shù)組

2009-09-17 17:40:36

C#動(dòng)態(tài)數(shù)組

2009-09-17 17:44:51

C#動(dòng)態(tài)數(shù)組

2019-11-04 13:50:36

Java數(shù)組編程語言

2021-07-06 06:39:22

Java靜態(tài)代理動(dòng)態(tài)代理

2009-12-09 14:08:00

靜態(tài)路由動(dòng)態(tài)路由

2010-02-03 10:11:17

C++動(dòng)態(tài)數(shù)組

2009-09-17 18:07:22

C#動(dòng)態(tài)數(shù)組

2009-09-02 11:02:57

C#動(dòng)態(tài)數(shù)組

2009-09-01 18:32:32

C#動(dòng)態(tài)數(shù)組

2016-08-03 17:23:47

javascripthtml前端

2022-06-01 08:12:32

JS類數(shù)組對象

2009-09-02 18:41:18

C#定義動(dòng)態(tài)控件數(shù)組

2009-09-02 11:18:10

C#動(dòng)態(tài)數(shù)組

2009-12-02 14:46:44

靜態(tài)路由動(dòng)態(tài)路由

2009-12-10 14:13:01

靜態(tài)路由動(dòng)態(tài)路由協(xié)議
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精品99久久久久久久久 | 成人精品国产免费网站 | 99亚洲精品 | 性生生活大片免费看视频 | 国产精品a一区二区三区网址 | 亚洲一区二区三区欧美 | 久久狠狠| 精品视频免费 | 自拍第1页 | 色橹橹欧美在线观看视频高清 | 午夜电影网| 成人欧美一区二区三区在线播放 | 欧美精品久久久 | 国产午夜视频 | 国产在线精品一区二区 | 欧美视频二区 | 国产二区视频 | 成人精品一区二区三区 | 欧美激情一区 | 99精品久久久国产一区二区三 | 午夜免费av | 国产99久久久国产精品 | 一级毛片免费 | 久草中文在线 | 国产一区二区三区四区在线观看 | www.日韩高清 | 午夜精品一区二区三区在线观看 | 99成人 | 免费观看成人鲁鲁鲁鲁鲁视频 | 国产精品天堂 | 欧美理伦片在线播放 | 一区二区三区亚洲精品国 | 国产亚洲精品精品国产亚洲综合 | 粉嫩一区二区三区国产精品 | 日韩视频精品在线 | 色在线免费 | 免费av直接看 | 成人乱人乱一区二区三区软件 | 久久精品国产免费一区二区三区 | 免费一区 | 高清人人天天夜夜曰狠狠狠狠 |