日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

数据结构(一)--ArrayList and LinkerList

發布時間:2024/1/8 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据结构(一)--ArrayList and LinkerList 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天我帶大家一起學習java中的容器部分,首先我們來看一下ArrayList。
我們需要先明確的是,有些時候我們需要不斷的向一個庫中添加或者刪除元素,我們首先自然而然想到的就是數組,然而數組并不支持擴展內存,我們只能初始化固定數組的長度,然而我們往往會造成內存空間的浪費,或者我們創建數組的長度無法滿足我們實際情況的需要,這時java為我們提供了容器這個概念,我們今天首先了解下其中的ArrList
List 接口的大小可變數組的實現。實現了所有可選列表操作,并允許包括 null 在內的所有元素。除了實現 List 接口外,此類還提供一些方法來操作內部用來存儲列表的數組的大小.
每個 ArrayList 實例都有一個容量。該容量是指用來存儲列表元素的數組的大小。它總是至少等于列表的大小。隨著向 ArrayList 中不斷添加元素,其容量也自動增長。并未指定增長策略的細節,因為這不只是添加元素會帶來分攤固定時間開銷那樣簡單。
我們先來看下ArrayList里的方法


接下來我們用代碼實現一遍

package com.wanghaixueStudy.cn;import java.util.ArrayList;/*** 本程序我們來學習一下ArrayList的基本用法* @author lover**/ class student{ //創建一個類資源private String name;private boolean sex;public String getName() {return name;}public void setName(String name) {this.name = name;}public boolean getSex() {return sex;}public void setSex(boolean sex) {this.sex = sex;} } public class ArraylistText { public static void main(String[] args) {//創建三個student對象student s1=new student();s1.setName("王海學");s1.setSex(true);student s2=new student();s2.setName("邵玥");s2.setSex(false);student s3=new student();s3.setName("豬");s3.setSex(true);//創建ArrayList集合ArrayList arr=new ArrayList();//增-->向arr容器中增加student對象arr.add(s1);arr.add(s2);arr.add(s3);//查-->我們查詢arr容器里的對象for(int i=0;i<arr.size();i++){student s=(student) arr.get(i);System.out.println(s.getName()+":"+s.getSex());}//刪-->刪除arr中的對象arr.remove(0);arr.remove(s3);for(int i=0;i<arr.size();i++){student s=(student) arr.get(i);System.out.println(s.getName()+":"+s.getSex());}arr.add(s1);arr.add(s3);//判斷arr容器里是否包含某一對象System.out.println(arr.contains(s2));//將容器轉換為數組Object obj[]=arr.toArray();} }

看一下輸出結果

王海學:true 邵玥:false 豬:true 邵玥:false true

(二)LinkerList
List 接口的鏈接列表實現。實現所有可選的列表操作,并且允許所有元素(包括 null)。除了實現 List 接口外,LinkedList 類還為在列表的開頭及結尾 get、remove 和 insert 元素提供了統一的命名方法。這些操作允許將鏈接列表用作堆棧、隊列或雙端隊列。
所有操作都是按照雙重鏈接列表的需要執行的。在列表中編索引的操作將從開頭或結尾遍歷列表(從靠近指定索引的一端)。


package com.wanghaixueStudy.cn;import java.util.LinkedList;/*** 本程序我們學習LinkerList* @author lover**/ class student{ //創建一個類資源private String name;private boolean sex;public String getName() {return name;}public void setName(String name) {this.name = name;}public boolean getSex() {return sex;}public void setSex(boolean sex) {this.sex = sex;} } public class LinkerListText { public static void main(String[] args) {//創建LinkerList容器LinkedList lin=new LinkedList();//創建三個student對象student s1=new student();s1.setName("王海學");s1.setSex(true);student s2=new student();s2.setName("邵玥");s2.setSex(false);student s3=new student();s3.setName("豬");s3.setSex(true);//增-->向arr容器中增加student對象lin.add(s1);//我們還可以向開始添加 和最后添加lin.addFirst(s2);lin.addLast(s3);//查-->我們查詢arr容器里的對象for(int i=0;i<lin.size();i++){student s=(student) lin.get(i);System.out.println(s.getName()+":"+s.getSex());}//刪-->刪除arr中的對象lin.remove(0);lin.remove(s3);for(int i=0;i<lin.size();i++){student s=(student) lin.get(i);System.out.println(s.getName()+":"+s.getSex());}lin.add(s1);lin.add(s3);//判斷arr容器里是否包含某一對象System.out.println(lin.contains(s2));} }

我們看下輸出結果

邵玥:false 王海學:true 豬:true 王海學:true false

相比與ArrayList,LinkerList不是按物理結構排的,它采用雙向鏈表的形式,頭指向前一個元素的尾,前一個元素的尾同樣指向這個元素的頭。因而增加了很多的方法,小伙伴們可以一一嘗試。

(三)ArrayList和LinkerList的區別
1、同步性

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

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

3、檢索、插入、刪除對象的效率

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

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

總結

以上是生活随笔為你收集整理的数据结构(一)--ArrayList and LinkerList的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。