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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...