Java之List和Set

来源:https://www.cnblogs.com/wadmwz/archive/2018/07/14/9308409.html
-Advertisement-
Play Games

List、Set、數據結構、Collections 初次學習,涉及到List集合,Set集合和數據結構方面的一些知識,有錯誤還請批評指正 數據結構 數據存儲的常用結構有:棧、隊列、數組、鏈表和紅黑樹。 棧 先進後出(FILO). 隊列 先進先出(FIFO). 數組 有序的元素序列,以索引訪問.查詢快 ...


List、Set、數據結構、Collections

初次學習,涉及到List集合,Set集合和數據結構方面的一些知識,有錯誤還請批評指正

數據結構

數據存儲的常用結構有:棧、隊列、數組、鏈表和紅黑樹。

先進後出(FILO).

隊列

先進先出(FIFO).

數組

有序的元素序列,以索引訪問.查詢快,增刪慢.

鏈表

鏈式結構,查詢慢,增刪快.通過地址進行連接.
單向鏈表:結點包括兩個內容,一個是存儲元素,一個是下一個元素的地址.
雙向鏈表:結點包括3個部分,前一個元素的存儲地址,當前結點存儲的元素,後一個元素的存儲地址

紅黑樹

二叉樹,查詢快.根節點的左邊數據小於右邊數據.

關於使用java具體實現上面的數據結構以後寫,當前只需要瞭解一下他們的特性就可以.

List集合

java.util.List 介面繼承自Collection 介面,是單列集合的一個重要分支,在List集合中允許出現重覆的元素,所有的元素是以一種線
性方式進行存儲的,在程式中可以通過索引來訪問集合中的指定元素。另外,List集合還有一個特點就是元素有序,即元素的存入順序和
取出順序一致。(remove(Object obj)只能移除集合中第一個相同的元素)

List集合的特點:

  • 元素存儲有序.
  • 可以存儲重覆元素
  • 有索引,可以通過索引來訪問元素

常用的方法有(list的特有方法大都與索引相關):

  • public void add(int index, E element) : 將指定的元素,添加到該集合中的指定位置上。
  • public E get(int index) :返回集合中指定位置的元素。
  • public E remove(int index) : 移除列表中指定位置的元素, 返回的是被移除的元素。
  • public E set(int index, E element) :用指定元素替換集合中指定位置的元素,返回值的更新前的元素。

List的子類

  • Vector : 線程安全相關
  • ArrayList : 底層數組實現
  • LinkedList : 鏈表實現
ArrayList

特有的常用方法:

  • int indexOf(Object o) 返回此列表中指定元素的第一次出現的索引,如果此列表不包含元素,則返回-1。
LinkedList

java.util.LinkedList 集合數據存儲的結構是鏈表結構。方便元素添加、刪除的集合。

  • 鏈表結構,查詢慢,增刪快
  • 包含大量操作首尾元素的方法

特有的方法:

  • public void addFirst(E e) :將指定元素插入此列表的開頭。
  • public void addLast(E e) :將指定元素添加到此列表的結尾。
  • public void push(E e) :將元素推入此列表所表示的堆棧。等效於addFirst

  • public E getFirst() :返回此列表的第一個元素。
  • public E getLast() :返回此列表的最後一個元素。
  • E get(int index) 返回此列表中指定位置的元素。

  • public E removeFirst() :移除並返回此列表的第一個元素。
  • public E removeLast() :移除並返回此列表的最後一個元素。
  • public E pop() :從此列表所表示的堆棧處彈出一個元素。等效於removeFirst

  • int indexOf(Object o) 返回此列表中指定元素的第一次出現的索引,如果此列表不包含元素,則返回-1。
  • public boolean isEmpty() :如果列表不包含元素,則返回true。

Vector

這個在使用上和ArrayList基本沒有區別,要註意的是二者的區別:

相同點:

  • 二者的底層實現都是數組結構.
    不同點:
  • Vector是與線程安全相關的,效率低下.ArrayList是線程不安全的,但是高效.

Set介面

java.util.Set介面特點:

  • 不允許存儲重覆元素
  • 無索引(意味著不能用普通for迴圈遍歷)

HashSet

特點:

  • 不允許存儲重覆元素(存儲相同的元素在Set中只能保存一個,但程式不會出錯)
  • 無索引(意味著不能用普通for迴圈遍歷)
  • 存儲和讀取元素無序(順序可能不一致,在底層Set有他自己的排序規則)
  • 底層使用哈希表結構

哈希值:

  • int hashCode() 返回對象的哈希碼值。

HashSet集合存儲數據的結構:

  • jdk8之前是:數組 + 鏈表
  • jdk8之後是:數組 + 紅黑樹(二叉樹)
  • 數組保存哈希值,存儲元素時,哈希值相同的保存在數組的下方.
  • 當有多個元素的哈希值相同時(哈希衝突),這個時候保存的時候就會繼續向下排列.具體的看下圖.
  • 當有8個及以上的元素的哈希值相同,鏈式結構就會轉化為紅黑樹結構.

HashSet如何保證元素唯一?與hashCode()方法與equals()方法相關:
HashSet元素唯一原理

舉個例子:

public class HashSet {

    public static void main(String[] args) {
        Set<String> set = new java.util.HashSet<>();
        set.add(new String("abc"));
        set.add(new String("abc"));
        set.add("abc");
        set.add("重地");
        set.add("通話");

        System.out.println(set); // [重地, 通話, abc]
    }
}

重地和通話兩個字元串比較特殊,二者的哈希值相同,從這個例子也可以看出String重寫了hashCode()和equals()方法.

LinkedHashSet

特點:

  • 有序
  • 沒有索引
  • 不可以存儲重覆元素
    哈希表(數組 + 鏈表/紅黑樹) + 鏈表(最後的鏈表是用來存儲存入順序的)

可變參數

定義格式:

修飾符 返回類型 方法名(參數類型...參數名){}

特點:

  • 可變參數底層實現是數組

註意事項:可變參數必須在參數列表的最後一位,一個參數列表只能有一個可變參數.

Collections

工具類特點:

  • 構造方法私有.
  • 所有的方法和屬性靜態,直接用類名調用.

常用方法:
public static

Comparatable與Comparator

Comparable:強行對實現它的每個類的對象進行整體排序。這種排序被稱為類的自然排序,類的compareTo方法
被稱為它的自然比較方法。只能在類中實現compareTo()一次,不能經常修改類的代碼實現自己想要的排序。實現
此介面的對象列表(和數組)可以通過Collections.sort(和Arrays.sort)進行自動排序,對象可以用作有序映射中
的鍵或有序集合中的元素,無需指定比較器。
Comparator強行對某個對象進行整體排序。可以將Comparator 傳遞給sort方法(如Collections.sort或
Arrays.sort),從而允許在排序順序上實現精確控制。還可以使用Comparator來控制某些數據結構(如有序set或
有序映射)的順序,或者為那些沒有自然順序的對象collection提供排序。

二者都存在時,優先使用Comparator.

Comparatable的例子:

public class Student implements Comparable<Student>{

    private String name;

    private int age;

    public Student() {
    }

    public Student(String name, int age) {

        this.name = name;
        this.age = age;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getName() {

        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public boolean equals(Object o) {

        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return age == student.age &&
                Objects.equals(name, student.name);
    }

    @Override
    public int hashCode() {

        return Objects.hash(name, age);
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }


    @Override
    public int compareTo(Student o) {
        return this.age - o.age;
    }
}

ArrayList<String> list = new ArrayList<>();

Collections.addAll(list,"迪麗熱巴","鄭爽","李溪芮");

System.out.println(list);

Collections.sort(list);

System.out.println(list);

Comparator的例子:

// 還是上面的實體類
ArrayList<Student> list = new ArrayList<>();

list.add(new Student("Silme",20));
list.add(new Student("Roke",19));
list.add(new Student("Aoke",19));
list.add(new Student("Robin",18));
System.out.println(list);
Collections.sort(list, new Comparator<Student>() {
    @Override
    public int compare(Student o1, Student o2) {
        // 年齡自然排序
        int flag = o1.getAge() - o2.getAge();
        // 年齡相同,按照姓名排序
        if(flag == 0){
            flag = o1.getName().charAt(0)- o2.getName().charAt(0);
        }
        return flag;
    }
});
System.out.println(list);

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • function Obj(){} Obj.prototype={ scroll:function(){ /* 主要是做相容處理 這裡必須時!=null 因為預設值和每次滾動的時侯 都可以值為0 但是 if(0)為假 所以就只要不為null 就執行 ... ...
  • 仿Jquery查詢 ...
  • 背景 因為歷史原因,之前很多的系統都會是 頂級頁面+Iframe來載入子級頁面的這種模式構件系統,而且系統都只能運行在IE6或者IE 高版本相容模式下(IE 7模式)。 隨著現在的審美原來越高,腳本能里越來越強,無論是用戶和是軟體商都希望能系統升級,那麼在升級的過程中,肯定是要保證原有的系統能正常運 ...
  • 涉及知識點: 1、垂直排列,水平排列 2、居中對齊 示例: 1、預設排版 , 一個父組件裡面兩個子view 顯示效果: 2、先給父view設置一個高度和顏色值,用於看效果 3、實現水平排列和垂直排列的樣式 水平排列: > 垂直排列(不進行設置,預設垂直排列): > 4、實現居中效果 居中效果分為兩種 ...
  • 使用yarn的優點,簡而言之就是:鎖定版本,下載之前檢查完整性。 輸入 yarn --help 可以獲得幫助 ...
  • 喜歡的朋友可以關註下,粉絲也缺。 自從Spring推出Boot,Cloud系列之後,一度成為熱門的框架,現在大部分的招聘要求都要有相關的開發經驗,藉此我在這裡就給大家分享一下如何玩轉SpringBoot跟Mybatis。 這裡我給大家提供我創建的demo下載地址 https://download.c ...
  • 控制反轉是應用於軟體工程領域中的,在運行時被裝配器對象來綁定耦合對象的一種編程技巧,對象之間耦合關係在編譯時通常是未知的。在傳統編程方式中,業務邏輯的流程是應用程式中早已被設定好關聯關係的對象來決定的。在使用控制反轉的情況下,業務邏輯的流程是由對象關係圖來決定的,該對象關係圖有裝配器負責實例化,這種 ...
  • 在大容量,高負荷的web系統中,對資料庫進行一系列拆分,可有效提升資料庫容量和性能。在初學程式的早期,程式員通常都喜歡按傳統資料庫設計模式,設計為單庫和單一功能表的結構,這樣的結構在數據量和併發量達到一定程度之後,會出現嚴重性能問題和維護問題。在出現問題的時候才著手進行優化,會非常痛苦,所以應該在系 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...