017.3 集合

来源:https://www.cnblogs.com/-nbloser/archive/2018/04/06/8729424.html
-Advertisement-
Play Games

內容:j集合頂層共性的方法,集合下的兩個分支List和Set集合下的小分支——LinkedList、ArrayList、TreeSet、HashSet 在util包###頂層的共性介面collection方法 兩種集合List:有序(存入的順序和取出的順序一致)。有索引,允許重覆元素Set:不允許重 ...


 內容:j集合頂層共性的方法,集合下的兩個分支List和Set集合下的小分支——LinkedList、ArrayList、TreeSet、HashSet

在util包
###頂層的共性介面collection方法

//添加
Collection<String> c1 = new ArrayList<String>();
Collection<String> c2 = new ArrayList<String>();
c1.add("x");
c1.add("i");
c1.add("u");

c2.add("g");
c2.add("ha");
c2.add("ai");
//添加所有
c1.addAll(c2);
//System.out.println(c1);

//刪除相同的元素
c1.removeAll(c2);
//System.out.println(c1);

//刪除不同的元素
c1.retainAll(c2);

//獲取長度
c1.size()

//判斷是否包含元素
c1.contains("xia")                         //調用的是對象的equals方法

//將集合轉成數組
.toArray()

//取出元素
Iterator<String> it = c1.iterator();
while(it.hasNext()){
    String x = it.next();
    System.out.println(x);
}
開發中用的是for
for (Iterator<String> it = c1.iterator(); it.hasNext();) {
    String s = (String) it.next();
    System.out.println(s);
}

兩種集合
List:有序(存入的順序和取出的順序一致)。有索引,允許重覆元素
Set:不允許重覆元素

###List特有方法

import java.util.List;
List<String> list = new ArrayList<String>();

list.add("abc1");
list.add("abc2");
list.add("abc3");

//索引插入元素
list.add(1,"haha");

//索引刪除元素
list.remove(1);

//獲取
System.out.println(list.get(1));
System.out.println(list.indexOf("abc3"));

//修改
list.set(1, "kk");

//索引取出
for (int i = 0; i < list.size(); i++) {
    System.out.println(list.get(i));
}

//列表迭代器,解決迭代器過程中的增刪改查
for (ListIterator<String> it = list.listIterator(); it.hasNext();) {
    Object obj = it.next();
    if(obj.equals("abc2")){
        it.add("ai q");
    }
}

list集合具體子類
    Vector:數據結構是數組,可變長度的(不斷new新數據並將元數組複製到新數組)。線程同步的。增刪和查詢都慢
    ArrayList:也是數組結構,長度可變。線程不同步,代替了Vector。增刪速度不快,查詢速度快
    LinkedList:鏈表結構,線程不同步。增刪速度快,查詢速度慢

存儲自定義對象

對象的set、get方法快速創建,Alt+Shift+S

 

##ArrayList

存儲個人的對象
ArrayList<Person_arraylist> al = new ArrayList<Person_arraylist>();
Person_arraylist p1 = new Person_arraylist("ia", 21);
Person_arraylist p2 = new Person_arraylist("u",20);
al.add(p1);
al.add(p2);
al.add(new Person_arraylist("ai", 7));

for (Iterator it = al.iterator(); it.hasNext();) {
    Person_arraylist p = (Person_arraylist) it.next(); //需要向下轉型,才能進去的時候是Object類
    System.out.println(p.getName());
}

#去除重覆對象練習
Person_arraylist類中的equals方法
public boolean equals(Object obj){
    if(this == obj){
        return true;
    }
    if(!(obj instanceof Person_arraylist)){
        throw new ClassCastException("類型錯誤");
    }
    Person_arraylist p = (Person_arraylist)obj;
    return this.getName().equals(p.getName()) && this.getAge() == p.getAge();

public static void single_list(ArrayList<Person_arraylist> al){
    ArrayList<Person_arraylist> tmp = new ArrayList<Person_arraylist>();
    for (Iterator it = al.iterator(); it.hasNext();) {
        Person_arraylist p = (Person_arraylist) it.next();
        if(!tmp.contains(p)){           //通過contains調用Person_arraylist的比較方法,上面
            tmp.add(p);
        }
    }
    al.clear();
    al.addAll(tmp);
}

##LinkedList

一般都是頭尾操作
LinkedList<String> link = new LinkedList<String>();
link.addFirst("a");
link.addFirst("ai");
link.addFirst("iu");
//獲取元素,只是獲取沒有刪除
System.out.println(link.getFirst());
//獲取並且刪除元素
System.out.println(link.removeFirst());

判斷是否為空:isEmpty()

 

###Set集合:不允許重覆元素
和collection方法相同,只有一個迭代器
HashSet:哈希(散列)表結構
TreeSet:

 

 ##HashSet

Set<String> set = new HashSet<String>();
set.add("ia");
set.add("u");
set.add("ai");
set.add("pingpang");
set.add("xingfu");
//只能通過迭代器取出
for (Iterator it = set.iterator(); it.hasNext();) {
    String str = (String) it.next();
    System.out.println(str);
}

HashSet預設調用的是Object裡面的hashcode()方法,一般保存對象都需要對象覆蓋hashcode和equals方法
hashcode()方法,根據自身特點定義hash值,返回一個整數值,當返回的整數值相同就會調用equals方法進行比較。
equals()方法是為瞭解決hash衝突
要實現有序的話,使用LinkedHashSet對象

##TreeSet

 

1)第一種要求保存的對象要實現Comparable介面,實現compareTo方法。
public int compareTo(Object o)
{
    Student stu = (Student)o;
    if(this.age > stu.age){
        return 1;
    }
    if(this.age < stu.age){
        return -1;
    }
    return 0;
}        //簡單的compareTo方法實現,或者直接return  this.age-stu.age


public int compareTo(Object o)
{
    Student stu = (Student)o;
    return this.name.compareTo(stu.name);
}
TreeSet是根據compareTo方法返回的值來保證唯一性,所以單單使用一個沒有辦法保證不會出錯,萬一兩個年齡相同姓名不同,或者姓名相同年林不同的,這樣子會漏掉要保存的。
這裡解決辦法可以把return  0改成 return   this.name.compareTo(stu.name)
2)第二種要求建立指定排序方式的
在創建集合對象的時候,參數使用實現comparator介面的一個比較對象
public class Comparator_by_name implements Comparator<Student>
{
    public int compare(Student o1, Student o2)
    {
        int tmp = o1.getName().compareTo(o2.getName());
        return tmp==0?o1.getAge()-o2.getAge():tmp;
    }
}

ArrayList:數組結構。數組查詢快,list,可以重覆
LinkedList:鏈表結構。增刪快,***First   ***Last   ***為add get remove
HashSet:哈希表,查詢速度更快,不保證有序。
LinkedHashSet:鏈表+哈希表。可以實現有序
TreeSet:二叉樹,可以排序。兩種比較方式:一種是自然排序Comparable,一種是比較器Comparator

##foreach語句:for迴圈增強型
for(元素類型 變數:collection容器or數組){}

Collection<String> coll=new ArrayList<String>();
coll.add("a");
coll.add("ai");
coll.add("q");
coll.add("xa");
for(String s:coll){
    System.out.println(s);
}

 

###############################
//作業:List集合中存儲的重覆字元串元素,按照長度進行排序。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test2 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<String>();
        list.add("nba");
        list.add("abcde");
        list.add("nba");
        list.add("cctv");
        list.add("zz");
        list.add("cctv");
        list.add("itcast");
        
        Collections.sort(list,new Comparator<String>() {
            public int compare(String o1, String o2) {
                int temp = o1.length() - o2.length();
                return temp==0?o1.compareTo(o2):temp;
            }
            
        });
        
        for(String str : list){
            System.out.println(str);
        }
    }

}
View Code

 

#############################
//在一個已排序的List集合中插入一個字元串,繼續保證這個集合原有排序,問如何獲取這個位置。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test3 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<String>();
        list.add("nba");
        list.add("abcde");
        list.add("nba");
        list.add("cctv");
        list.add("zz");
        list.add("cctv");
        list.add("itcast");

        Collections.sort(list);
        String key =  "haha";
        //找一個元素在集合中出現的位置。
        int index = Collections.binarySearch(list, key);
        System.out.println("index="+index);
        
        if(index<0){
            index = -(index+1);
        }
        
        System.out.println("index="+index);
        System.out.println(list);
        list.add(index, key);
        
        System.out.println(list);
    }
}
View Code

 

 





 


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

-Advertisement-
Play Games
更多相關文章
  • 進程的三態模型 細分進程狀態圖 進程的通信 互斥:一次只能供一個進程使用的資源。 同步:多個進程併發進行,可能需要等待。 生產者與消費者 PV操作 PV操作是實現進程同步與互斥的常用方法,在執行期間不可分割。P代表申請一個資源,V代表釋放一個資源。 P操作定義 :S1:=S1-1,若S>=0,則P操... ...
  • 觀察者模式通常的叫法叫做訂閱 發佈模式,類似於報刊雜誌的訂閱,觀察者和被觀察者就是讀者和郵局的關係,讀者先要在郵局訂閱想要的報刊,當報刊發行時,郵局會將報刊郵寄到讀者家裡。觀察者(Observer)和被觀察者(Listener)也是這種關係,Observer將自己attach到Listener中,當 ...
  • 服務拆分具體拆分到多細,業內沒有一個統一的標準。當然也不能為了拆分而拆分,還要依據具體的業務場景應用情況而定,讀過《淘寶技術這十年》的朋友,相信對淘寶的技術演進有一個很直觀的感受。雖然當時微服務的概念並不今天這般火熱,但實際已經在生產環境中運行。 simplemall項目的業務背景基於簡單的購物場景 ...
  • 編譯過程 詞法分析:對源程式從前到後(從左至右)逐個字元地掃描,從而識別出一個個"單詞"符號。 語法分析:判斷語法是否出錯,如表達式、迴圈語句、程式等。 語義分析:檢查如賦值語句左右是否匹配,是否有零除數等。 文法 G={Vt*Vn*S*P} Vt是一個非空有限的符號集合,它的每個元素稱為終結符。 ... ...
  • 題目鏈接 "簡單的數學題" 題目描述 輸入一個整數n和一個整數p,你需要求出 $$\sum_{i=1}^n\sum_{j=1}^n (i\cdot j\cdot gcd(i,j))\ mod\ p$$ 其中$gcd(a,b)$表示$a$與$b$的最大公約數 輸入 一行兩個整數$p,n$ 輸出 一行一 ...
  • 參考資料:網易雲網課地址 http://study.163.com/course/courseMain.htm?courseId=1455026 一、String類的兩種實例化方法 (1)直接賦值 以上代碼可以輸出str的值,說明str 已被實例化(未實例化會為null)。我們知道String類並不 ...
  • 線程是程式執行的最小單元,多線程是指程式同一時間可以有多個執行單元運行(這個與你的CPU核心有關)。 在java中開啟一個新線程非常簡單,創建一個Thread對象,然後調用它的start方法,一個新線程就開啟了。 那麼執行代碼放在那裡呢?有兩種方式:1. 創建Thread對象時,覆寫它的run方法, ...
  • c++ 異常 abort() abort() 函數原型在頭文件cstdlib中 實現方式是:想標準錯誤流發送消息abnormal program termination 然後終止程式 返回一個隨實現而異的值 也可使用exit() 該函數刷新文件緩衝區 但是不顯示消息 返回錯誤碼 一種比異常終止更靈活 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...