中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java集合的示例分析

發布時間:2021-08-05 09:28:52 來源:億速云 閱讀:126 作者:小新 欄目:開發技術

這篇文章主要介紹了java集合的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

    一、簡介

    1、java集合框架圖

    java集合的示例分析

    從上面的集合框架圖可以看到,Java 集合框架主要包括兩種類型的容器,一種是集合(Collection),存儲一個元素集合,另一種是圖(Map),存儲鍵/值對映射。Collection 接口又有 3 種子類型,List、Set 和 Queue,再下面是一些抽象類,最后是具體實現類,常用的有 ArrayList、LinkedList、HashSet、LinkedHashSet、HashMap、LinkedHashMap 等等。

    集合框架是一個用來代表和操縱集合的統一架構。所有的集合框架都包含如下內容:

    • 接口:是代表集合的抽象數據類型。例如 Collection、List、Set、Map 等。之所以定義多個接口,是為了以不同的方式操作集合對象

    • 實現(類):是集合接口的具體實現。從本質上講,它們是可重復使用的數據結構,例如:ArrayList、LinkedList、HashSet、HashMap。

    • 算法:是實現集合接口的對象里的方法執行的一些有用的計算,例如:搜索和排序。這些算法被稱為多態,那是因為相同的方法可以在相似的接口上有著不同的實現。

    除了集合,該框架也定義了幾個 Map 接口和類。Map 里存儲的是鍵/值對。盡管 Map 不是集合,但是它們完全整合在集合中。

    2、集合框架體系

    java集合的示例分析

    3、Set和List的區別

    1)Set 接口實例存儲的是無序的,不重復的數據。List 接口實例存儲的是有序的,可以重復的元素

    2)Set 接口實例存儲的是無序的,不重復的數據。List 接口實例存儲的是有序的,可以重復的元素

    3)List和數組類似,可以動態增長,根據實際存儲的數據的長度自動增長List的長度。查找元素效率高,插入刪除效率低,因為會引起其他元素位置改變 <實現類有ArrayList,LinkedList,Vector>

    二、ArrayList

    1、定義

    ArrayList 類是一個可以動態修改的數組,與普通數組的區別就是它是沒有固定大小的限制,我們可以添加或刪除元素。

    ArrayList 繼承了 AbstractList ,并實現了 List 接口。

    java集合的示例分析

    ArrayList 類位于 java.util 包中,使用前需要引入它,語法格式如下:

    import java.util.ArrayList; // 引入 ArrayList 類
    ArrayList<E> objectName =new ArrayList<>();  // 初始化

    2、用實例了解ArrayList

    @Test
    	public void listTest(){
    		List<Integer> list = new ArrayList<Integer>();
    		//增加元素
    		list.add(1);
    		list.add(9);
    		list.add(8);
    		list.add(4);
    		list.add(5);
    		list.add(3);
    		//訪問
    		System.out.println("list新增完元素訪問:");
    		for(int s : list){
    			System.out.print(s+" ");
    		}
    		System.out.println();
    		//用set方法修改
    		list.set(2, 10);
    		//訪問
    		System.out.println("list修改完元素訪問:");
    		for(int s : list){
    			System.out.print(s+" ");
    		}
    		System.out.println();
    		list.remove(2);
    		//訪問
    		System.out.println("list刪除完元素訪問:");
    		for(int s : list){
    			System.out.print(s+" ");
    		}
    		System.out.println();
    		//當前list大小
    		System.out.println("list當前數據元素個數:"+list.size());
    		//排序
    		Collections.sort(list);//默認升序
    		//訪問
    		System.out.println("list排序完元素訪問:");
    		for(int s : list){
    			System.out.print(s+" ");
    		}
    		System.out.println();
    	}

    結果:

    list新增完元素訪問:
    1 9 8 4 5 3
    list修改完元素訪問:
    1 9 10 4 5 3
    list刪除完元素訪問:
    1 9 4 5 3
    list當前數據元素個數:5
    list排序完元素訪問:
    1 3 4 5 9

    Java ArrayList 常用方法列表如下:

    方法描述
    add()將元素插入到指定位置的 arraylist 中
    addAll()添加集合中的所有元素到 arraylist 中
    clear()刪除 arraylist 中的所有元素
    clone()復制一份 arraylist
    contains()判斷元素是否在 arraylist
    get()通過索引值獲取 arraylist 中的元素
    indexOf()返回 arraylist 中元素的索引值
    removeAll()刪除存在于指定集合中的 arraylist 里的所有元素
    remove()刪除 arraylist 里的單個元素
    size()返回 arraylist 里元素數量
    isEmpty()判斷 arraylist 是否為空
    subList()截取部分 arraylist 的元素
    set()替換 arraylist 中指定索引的元素
    sort()對 arraylist 元素進行排序
    toArray()將 arraylist 轉換為數組
    toString()將 arraylist 轉換為字符串
    ensureCapacity()設置指定容量大小的 arraylist
    lastIndexOf()返回指定元素在 arraylist 中最后一次出現的位置
    retainAll()保留 arraylist 中在指定集合中也存在的那些元素
    containsAll()查看 arraylist 是否包含指定集合中的所有元素
    trimToSize()將 arraylist 中的容量調整為數組中的元素個數
    removeRange()刪除 arraylist 中指定索引之間存在的元素
    replaceAll()將給定的操作內容替換掉數組中每一個元素
    removeIf()刪除所有滿足特定條件的 arraylist 元素
    forEach()遍歷 arraylist 中每一個元素并執行特定操作

    三、LinkedList

    鏈表(Linked list)是一種常見的基礎數據結構,是一種線性表,但是并不會按線性的順序存儲數據,而是在每一個節點里存到下一個節點的地址。

    鏈表可分為單向鏈表和雙向鏈表。

    一個單向鏈表包含兩個值: 當前節點的值和一個指向下一個節點的鏈接

    java集合的示例分析

    一個雙向鏈表有三個整數值: 數值、向后的節點鏈接、向前的節點鏈接。

    java集合的示例分析

    Java LinkedList(鏈表) 類似于 ArrayList,是一種常用的數據容器。

    與 ArrayList 相比,LinkedList 的增加和刪除對操作效率更高,而查找和修改的操作效率較低。

    以下情況使用 ArrayList :

    頻繁訪問列表中的某一個元素。只需要在列表末尾進行添加和刪除元素操作。

    以下情況使用 LinkedList :

    你需要通過循環迭代來訪問列表中的某些元素。需要頻繁的在列表開頭、中間、末尾等位置進行添加和刪除元素操作。

    java集合的示例分析

    1、語法

    // 引入 LinkedList 類
    import java.util.LinkedList; 
    LinkedList<E> list = new LinkedList<E>();   // 普通創建方法
    或者
    LinkedList<E> list = new LinkedList(Collection<? extends E> c); // 使用集合創建鏈表

    2、示例

    @Test
    	public void linkListTest(){
    		LinkedList<Integer> nums = new LinkedList<Integer>();
    		//添加
    		nums.add(3);
    		nums.add(5);
    		nums.add(1);
    		nums.add(8);
            System.out.println(nums);
            // 使用 addFirst() 在頭部添加元素
            nums.addFirst(0);
            System.out.println(nums);
            nums.addLast(20);
            System.out.println(nums);
            //移除首位
            nums.removeFirst();
            System.out.println(nums);
            // 使用 getFirst() 獲取頭部元素
            System.out.println(nums.getFirst());
            //for循環迭代
            for (int size = nums.size(), i = 0; i < size; i++) {
                System.out.println(nums.get(i));
            }
    	}

    結果:

    [3, 5, 1, 8]
    [0, 3, 5, 1, 8]
    [0, 3, 5, 1, 8, 20]
    [3, 5, 1, 8, 20]
    3
    3
    5
    1
    8
    20

    方法描述
    public boolean add(E e)鏈表末尾添加元素,返回是否成功,成功為 true,失敗為 false。
    public void add(int index, E element)向指定位置插入元素。
    public boolean addAll(Collection c)將一個集合的所有元素添加到鏈表后面,返回是否成功,成功為 true,失敗為 false。
    public boolean addAll(int index, Collection c)將一個集合的所有元素添加到鏈表的指定位置后面,返回是否成功,成功為 true,失敗為 false。
    public void addFirst(E e)元素添加到頭部。
    public void addLast(E e)元素添加到尾部。
    public boolean offer(E e)向鏈表末尾添加元素,返回是否成功,成功為 true,失敗為 false。
    public boolean offerFirst(E e)頭部插入元素,返回是否成功,成功為 true,失敗為 false。
    public boolean offerLast(E e)尾部插入元素,返回是否成功,成功為 true,失敗為 false。
    public void clear()清空鏈表。
    public E removeFirst()刪除并返回第一個元素。
    public E removeLast()刪除并返回最后一個元素。
    public boolean remove(Object o)刪除某一元素,返回是否成功,成功為 true,失敗為 false。
    public E remove(int index)刪除指定位置的元素。
    public E poll()刪除并返回第一個元素。
    public E remove()刪除并返回第一個元素。
    public boolean contains(Object o)判斷是否含有某一元素。
    public E get(int index)返回指定位置的元素。
    public E getFirst()返回第一個元素。
    public E getLast()返回最后一個元素。
    public int indexOf(Object o)查找指定元素從前往后第一次出現的索引。
    public int lastIndexOf(Object o)查找指定元素最后一次出現的索引。
    public E peek()返回第一個元素。
    public E element()返回第一個元素。
    public E peekFirst()返回頭部元素。
    public E peekLast()返回尾部元素。
    public E set(int index, E element)設置指定位置的元素。
    public Object clone()克隆該列表。
    public Iterator descendingIterator()返回倒序迭代器。
    public int size()返回鏈表元素個數。
    public ListIterator listIterator(int index)返回從指定位置開始到末尾的迭代器。
    public Object[] toArray()返回一個由鏈表元素組成的數組。
    public T[] toArray(T[] a)返回一個由鏈表元素轉換類型而成的數組。

    四、HashSet

    1、定義

    HashSet 基于 HashMap 來實現的,是一個不允許有重復元素的集合。

    HashSet 允許有 null 值。

    HashSet 是無序的,即不會記錄插入的順序。

    HashSet 不是線程安全的, 如果多個線程嘗試同時修改 HashSet,則最終結果是不確定的。 您必須在多線程訪問時顯式同步對 HashSet 的并發訪問。

    HashSet 實現了 Set 接口。

    java集合的示例分析

    2、語法

    import java.util.HashSet; // 引入 HashSet 類
    HashSet<String> sites = new HashSet<String>();

    3、示例

    @Test
    	public void setTest(){
    		Set<Integer> nums = new HashSet<Integer>();
    		//添加
    		nums.add(3);
    		nums.add(5);
    		nums.add(5);
    		nums.add(5);
    		nums.add(1);
    		nums.add(8);
            System.out.println(nums);
            //判斷元素是否存在
            System.out.println(nums.contains(8));
            nums.remove(1);  // 刪除元素,刪除成功返回 true,否則為 false
            System.out.println(nums);
            //計算大小
            System.out.println(nums.size());
            for (int i : nums) {//訪問
                System.out.println(i);
            }
            //清除
            nums.clear();
            System.out.println(nums);
    	}

    結果:

    [1, 3, 5, 8]
    true
    [3, 5, 8]
    3
    3
    5
    8
    []

    五、HashMap

    1、定義

    HashMap 是一個散列表,它存儲的內容是鍵值對(key-value)映射。

    HashMap 實現了 Map 接口,根據鍵的 HashCode 值存儲數據,具有很快的訪問速度,最多允許一條記錄的鍵為 null,不支持線程同步。

    HashMap 是無序的,即不會記錄插入的順序。

    HashMap 繼承于AbstractMap,實現了 Map、Cloneable、java.io.Serializable 接口。

    java集合的示例分析

    HashMap 的 key 與 value 類型可以相同也可以不同,可以是字符串(String)類型的 key 和 value,也可以是整型(Integer)的 key 和字符串(String)類型的 value。

    java集合的示例分析

    2、語法

    import java.util.HashMap; // 引入 HashMap 類
    HashMap<Integer, String> Sites = new HashMap<Integer, String>();

    3、示例

    @Test
    	public void mapTest(){
    		 // 創建 HashMap 對象 Sites
            HashMap<String, String> sites = new HashMap<String, String>();
            // 添加鍵值對
            sites.put("one", "Google");
            sites.put("two", "Runoob");
            sites.put("three", "Taobao");
            sites.put("four", "Zhihu");
            System.out.println(sites);
            //訪問-根據key
            System.out.println(sites.get("four"));
            //刪除
            sites.remove("four");
            System.out.println(sites);
            //計算大小
            System.out.println(sites.size());
            // 輸出 key 和 value
            for (String i : sites.keySet()) {
                System.out.println("key: " + i + " value: " + sites.get(i));
            }
            // 返回所有 value 值
            for(String value: sites.values()) {
              // 輸出每一個value
              System.out.print(value + ", ");
            }
    	}

    結果:

    {four=Zhihu, one=Google, two=Runoob, three=Taobao}
    Zhihu
    {one=Google, two=Runoob, three=Taobao}
    3
    key: one value: Google
    key: two value: Runoob
    key: three value: Taobao
    Google, Runoob, Taobao,

    Java HashMap 方法

    hashmap

    Java HashMap 常用方法列表如下:

    方法描述
    clear()刪除 hashMap 中的所有鍵/值對
    clone()復制一份 hashMap
    isEmpty()判斷 hashMap 是否為空
    size()計算 hashMap 中鍵/值對的數量
    put()將鍵/值對添加到 hashMap 中
    putAll()將所有鍵/值對添加到 hashMap 中
    putIfAbsent()如果 hashMap 中不存在指定的鍵,則將指定的鍵/值對插入到 hashMap 中。
    remove()刪除 hashMap 中指定鍵 key 的映射關系
    containsKey()檢查 hashMap 中是否存在指定的 key 對應的映射關系。
    containsValue()檢查 hashMap 中是否存在指定的 value 對應的映射關系。
    replace()替換 hashMap 中是指定的 key 對應的 value。
    replaceAll()將 hashMap 中的所有映射關系替換成給定的函數所執行的結果。
    get()獲取指定 key 對應對 value
    getOrDefault()獲取指定 key 對應對 value,如果找不到 key ,則返回設置的默認值
    forEach()對 hashMap 中的每個映射執行指定的操作。
    entrySet()返回 hashMap 中所有映射項的集合集合視圖。
    keySet()返回 hashMap 中所有 key 組成的集合視圖。
    values()返回 hashMap 中存在的所有 value 值。
    merge()添加鍵值對到 hashMap 中
    compute()對 hashMap 中指定 key 的值進行重新計算
    computeIfAbsent()對 hashMap 中指定 key 的值進行重新計算,如果不存在這個 key,則添加到 hasMap 中
    computeIfPresent()對 hashMap 中指定 key 的值進行重新計算,前提是該 key 存在于 hashMap 中。

    六、Iterator(迭代器)

    1、定義

    Java Iterator(迭代器)不是一個集合,它是一種用于訪問集合的方法,可用于迭代 ArrayList 和 HashSet 等集合。

    Iterator 是 Java 迭代器最簡單的實現,ListIterator 是 Collection API 中的接口, 它擴展了 Iterator 接口。

    java集合的示例分析

    2、示例

    @Test
    	public void iteratorTest(){
    		List<Integer> list = new ArrayList<Integer>();
    		//增加元素
    		list.add(1);
    		list.add(9);
    		list.add(8);
    		list.add(4);
    		list.add(5);
    		list.add(3);
    		Iterator<Integer> it = list.iterator();
    		while(it.hasNext()){
    			int i = it.next();
    			System.out.print(i+" ");
    		}
    	}

    結果:

    1 9 8 4 5 3

    七、List和數組互轉

    @Test
    	public void arrToListTest(){
    		List<Integer> list = new ArrayList<Integer>();
    		//增加元素
    		list.add(1);
    		list.add(9);
    		list.add(8);
    		list.add(4);
    		list.add(5);
    		list.add(3);
    		Object[] arr = list.toArray();
    		for(Object o : arr){
    			System.out.print(o+" ");
    		}
    		System.out.println();
    		List<Object> ll = Arrays.asList(arr);
    		System.out.println(ll);
    	}

    結果:

    1 9 8 4 5 3
    [1, 9, 8, 4, 5, 3]

    感謝你能夠認真閱讀完這篇文章,希望小編分享的“java集合的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    罗田县| 萨嘎县| 盘山县| 杭锦后旗| 英超| 盐亭县| 东海县| 平谷区| 攀枝花市| 宁陵县| 阳城县| 安新县| 扬中市| 平果县| 科技| 阿拉善左旗| 拉孜县| 卓资县| 西乌珠穆沁旗| 岑溪市| 当雄县| 乐东| 高邑县| 凉城县| 金昌市| 屏边| 宝兴县| 乐安县| 齐齐哈尔市| 庆云县| 双鸭山市| 阿合奇县| 金沙县| 绥棱县| 抚州市| 新余市| 威海市| 宁海县| 甘德县| 兰州市| 彩票|