欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文掌握J(rèn)ava中List和Set接口的基本使用

 更新時(shí)間:2022年07月18日 08:58:12   作者:葉落秋白  
這篇文章主要為大家詳細(xì)介紹Java中List和Set接口,文中通過示例代碼讓大家能夠輕松掌握List和Set接口的基本使用,感興趣的可以跟隨小編一起學(xué)習(xí)一下

集合的概念

是一個(gè)工具類,作用為存儲(chǔ)多個(gè)數(shù)據(jù),通常用于替代數(shù)組

集合的特點(diǎn)

只能存放Object對(duì)象

  • 只能存放引用類型
  • 不能存放接口,只能存放接口實(shí)現(xiàn)類對(duì)象

來自java.util包

List接口

List的存儲(chǔ)特點(diǎn)

有序、有下標(biāo)、元素可以重復(fù)

常用實(shí)現(xiàn)類

1.ArrayList 最常用

JDK1.2 底層數(shù)組實(shí)現(xiàn) 查詢快、增刪慢 線程不安全,效率高

2.一般不用

JDK1.2 底層鏈表實(shí)現(xiàn) 增刪快,查詢慢 線程不安全,效率高

3.Vector 不用

JDK1.0 底層數(shù)組實(shí)現(xiàn) 都慢 線程安全,效率低

創(chuàng)建

通常使用多態(tài)

List 集合名=new 實(shí)現(xiàn)類名();

常用方法

集合名.方法名

  • boolean add(元素):將元素添加至集合末尾
  • void add(下標(biāo),元素):將元素添加至指定下標(biāo)位置
  • boolean addAll(集合名):將指定集合所有元素添加至當(dāng)前集合末尾
  • boolean addAll(下標(biāo),集合名):將指定集合所有元素添加至當(dāng)前集合指定下標(biāo)位置
  • void clear():清空集合元素
  • int size():獲取集合長(zhǎng)度
  • boolean contains(元素):判斷集合中是否包含指定元素
  • boolean containsAll(集合名):判斷集合中是否包含指定集合的所有元素
  • 元素 get(下標(biāo)):獲取指定下標(biāo)位置上的元素
  • int indexOf(元素):獲取指定元素第一次出現(xiàn)的下標(biāo),不存在返回-1
  • int lastIndexOf(元素):獲取指定元素最后一次出現(xiàn)的下標(biāo),不存在返回-1
  • boolean isEmpty():判斷集合元素是否為空,不能判比null值
  • 元素 remove(下標(biāo)):移除指定下標(biāo)的元素,返回該元素
  • 元素 set(下標(biāo),新值):將指定下標(biāo)位置的值替換為新值,返回舊值
  • void sort(比較器實(shí)現(xiàn)類對(duì)象):對(duì)集合元素按照指定規(guī)則排序
  • Object[] toArray():將集合轉(zhuǎn)換為數(shù)組

代碼示例

public class Test {
        public static void main(String[] args) {
            List list = new ArrayList();
            list.add(66);
            list.add(5);
            list.add(77);//66 5 77
    
            list.add(2,44);//66 5 44 77
    
            List list2 = new ArrayList();
            list2.add(2);
            list2.add(1);
    
            list.addAll(list2);//66 5 44 77 2 1
            list.addAll(1, list2);//66 2 1 5 44 77 2 1
    
            System.out.println("清空之前:"+list.size());
           // list.clear();
           // System.out.println("清空之后:"+list.size());
            System.out.println(list.contains(5));//t
            System.out.println(list.containsAll(list2));//t
    
            List list3 = new ArrayList();
            list3.add(66);
            list3.add(77);
            list3.add(88);
            System.out.println(list.containsAll(list3));//f
    
            System.out.println(list.get(3));//5
    
            System.out.println(list.indexOf(88));//-1
            System.out.println(list.lastIndexOf(2));//6
    
            //list.clear();
            System.out.println(list.isEmpty());
            List list4=null;
            //System.out.println(list4.isEmpty()); 空指針異常
    
            System.out.println(list.remove(3));//66 2 1 44 77 2 1
            // System.out.println(list.remove(2));
    
            list.set(1, 88);//66 88 1 44 77 2 1
    
            Object[] os=list.toArray();
            for(int i=0;i<os.length;i++){
                System.out.print(os[i]+" ");
            }
            System.out.println();
        }
    }

遍歷方法

for+get()

 for (int i = 0; i < 集合名.size(); i++) {
       //i代表當(dāng)前下標(biāo)
       //通過集合名.get(i)的方式獲取當(dāng)前元素
   }
   如:
 for (int i = 0; i < list.size(); i++) {
        System.out.print(list.get(i)+" ");
         }
        System.out.println();

迭代器遍歷

hasNext():判斷是否存在下一元素

next():指針后移,獲取下一元素

//獲取迭代器對(duì)象
Iterator it=集合名.iterator();
while(it.hasNext()){//集合存在下一元素則繼續(xù)后續(xù)操作
//通過it.next()使指針后移,得到元素
}
如:
Iterator it=list.iterator();
while(it.hasNext()){
System.out.print(it.next()+" ");
}
System.out.println();

tips:迭代過程中不允許對(duì)集合進(jìn)行增刪操作

外遍歷forEach

for(數(shù)據(jù)類型 元素名(隨便起) : 集合名){
//元素名就代表當(dāng)前元素
}

如:

for (Object o: list) {
System.out.print(o+" ");
}
System.out.println();

本質(zhì)也是迭代器遍歷,內(nèi)部不允許進(jìn)行增刪操作

JDK5.0

自遍歷forEach

//匿名內(nèi)部類
集合名.forEach(new Consumer() {
@Override
public void accept(Object o) {
//o就代表當(dāng)前元素
}
});

 //lambda簡(jiǎn)化
         集合名.forEach(o-> {o就代表當(dāng)前元素});
 如:
         list.forEach(new Consumer() {
             @Override
             public void accept(Object o) {
                 System.out.print(o + " ");
             }
         });
         System.out.println();
 
         // lambda
         list.forEach(o-> System.out.print(o+" "));

JDK8.0

泛型

作用

用于集合中,可以約束集合存儲(chǔ)的數(shù)據(jù)類型

語法

List<數(shù)據(jù)類型> 集合名=new 實(shí)現(xiàn)類名<數(shù)據(jù)類型>();

使用

1. 如果集合中存放基本類型,則泛型必須聲明為其包裝類型

2. 聲明泛型之后,集合中不允許存放其他類型的數(shù)據(jù)

3. 前后類型聲明必須一致

4. 等號(hào)后邊的泛型不聲明,語法不規(guī)范

5. 等號(hào)前邊的泛型不聲明,泛型無意義

List<Integer> list = new ArrayList<Integer>();
        list.add(66);
        list.add(88);
       /* list.add("abc");
        list.add(5.5);*/
        list.forEach(new Consumer<Integer>() {
            @Override
            public void accept(Integer i) {
                System.out.println(i);
            }
        });

Set接口

Collection

  • 是一個(gè)接口
  • 是List和Set的父接口
  • 所有集合都由Collection或Map派生

特點(diǎn)

存放著List和Set的共有方法

沒有自己的直接實(shí)現(xiàn)類

Set的存儲(chǔ)特點(diǎn)

無序、無下標(biāo)、元素不可重復(fù)

常用實(shí)現(xiàn)類

1.HashSet

JDK1.2 底層哈希表實(shí)現(xiàn)(數(shù)組+鏈表 又名散列表) 線程不安全,效率高

2.LinkedHashSet

JDK1.2 是HashSet的子類,底層哈希表實(shí)現(xiàn) 線程不安全,效率高

3.TreeSet

JDK1.2 是SortedSet的實(shí)現(xiàn)類,底層紅黑樹實(shí)現(xiàn) 線程不安全,效率高

創(chuàng)建

利用多態(tài)

Set<泛型類型> 集合名 = new 實(shí)現(xiàn)類名<泛型類型>();

常用方法

全部繼承自Collection

遍歷方法

  • Iterator迭代器遍歷
  • 外遍歷forEach
  • 自遍歷forEach

哈希表的去重過程

  • 先通過調(diào)用元素的hashCode()方法得到哈希碼值
  • 然后通過哈希碼值%數(shù)組長(zhǎng)度得到存放下標(biāo)
  • 若該下標(biāo)位置未存放元素,則直接存放
  • 若已存有元素,則調(diào)用當(dāng)前元素的equals()方法與其位置的所有元素進(jìn)行值的比較
  • 都不相同,則鏈表存放
  • 若有相同,舍棄當(dāng)前元素

注意事項(xiàng)

1.當(dāng)集合中存放的為自定義類型時(shí),必須重寫hashCode和equals才能保證去重

2.LinkedHashSet能夠保證元素存入和取出順序一致

3.TreeSet可以實(shí)現(xiàn)對(duì)元素進(jìn)行默認(rèn)的升序排序

a.如果存放的為自定義類型,必須重寫排序規(guī)則

b.兩種排序方式:

I.實(shí)現(xiàn)Comparable接口,重寫compareTo方法

要對(duì)誰排,就讓誰實(shí)現(xiàn)

原理:讓當(dāng)前對(duì)象與參數(shù)對(duì)象進(jìn)行比較

返回值規(guī)則:

  • 從小到大:this的值>o的值,返回正數(shù)
  • 從大到小:this的值>o的值,返回負(fù)數(shù)
  • 相等返回0

II.實(shí)現(xiàn)Comparator接口,重寫compare方法

在集合創(chuàng)建處的小括號(hào)內(nèi)傳入該接口的實(shí)現(xiàn)類對(duì)象

          public class Test2 {
            public static void main(String[] args) {
                Set<Student> set = new TreeSet<Student>(new Comparator<Student>() {
                    @Override
                    public int compare(Student o1, Student o2) {
                        //根據(jù)學(xué)生年齡從大到小排序
                        return o2.getAge()-o1.getAge();
                    }
                });
                set.add(new Student("張三", 20));
                set.add(new Student("lisi", 21));
                set.add(new Student("lisi", 21));
                set.add(new Student("wangwu", 22));
                set.add(new Student("maliu", 19));
                set.forEach(s-> System.out.println(s));
            }
        }
  • 默認(rèn)識(shí)別第一種排序方式
  • 第二種排序方式優(yōu)先級(jí)高于第一種

List和set的區(qū)別

基本概念的區(qū)別

List 接口是一個(gè)有序的 Collection,使用此接口能夠精確的控制每個(gè)元素插入的位置,能夠通過索引(元素在List中位置,類似于數(shù)組的下標(biāo))來訪問List中的元素,第一個(gè)元素的索引為 0,而且允許有相同的元素。List 接口存儲(chǔ)一組不唯一,有序的對(duì)象。

Set 具有與 Collection 完全一樣的接口,只是行為上不同,Set 不保存重復(fù)的元素。Set 接口存儲(chǔ)一組唯一,無序的對(duì)象。

1.Set 接口實(shí)例存儲(chǔ)的是無序的, 不重復(fù)的數(shù)據(jù), List 接口實(shí)例存儲(chǔ)的是有序的,可以重復(fù)的元素;

2.Set檢索效率低下, 刪除和插入效率高, 插入和刪除不會(huì)引起元素位置改變

3.List和數(shù)組類似, 可以動(dòng)態(tài)增長(zhǎng), 根據(jù)實(shí)際存儲(chǔ)的數(shù)據(jù)的長(zhǎng)度自動(dòng)增長(zhǎng)List的長(zhǎng)度, 查找元素效率高, 插入刪除效率低, 因?yàn)闀?huì)引起其他元素位置改變 <實(shí)現(xiàn)類有ArrayList,LinkedList,Vector> ;

使用場(chǎng)景

List

常用的實(shí)現(xiàn)類有 ArrayList、LinkedList 和 Vector。ArrayList 最為流行,它提供了使用索引的隨意訪問,而 LinkedList 則對(duì)于經(jīng)常需要從 List 中添加或刪除元素的場(chǎng)合更為合適。

set

Set 接口最流行的幾個(gè)實(shí)現(xiàn)類是 HashSet、LinkedHashSet 以及 TreeSet。最流行的是基于 HashMap 實(shí)現(xiàn)的 HashSet;TreeSet 還實(shí)現(xiàn)了 SortedSet 接口,因此 TreeSet 是一個(gè)根據(jù)其 compare() 和 compareTo() 的定義進(jìn)行排序的有序容器。

到此這篇關(guān)于一文掌握J(rèn)ava中List和Set接口的基本使用的文章就介紹到這了,更多相關(guān)Java List Set接口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳細(xì)圖解Java中字符串的初始化

    詳細(xì)圖解Java中字符串的初始化

    字符串廣泛應(yīng)用在Java編程中,在Java中字符串屬于對(duì)象,Java提供了String類來創(chuàng)建和操作字符串,下面這篇文章主要給大家介紹了Java中字符串初始化的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • SpringMVC?@RequestMapping注解屬性詳細(xì)介紹

    SpringMVC?@RequestMapping注解屬性詳細(xì)介紹

    通過@RequestMapping注解可以定義不同的處理器映射規(guī)則,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@RequestMapping注解用法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Spring Boot2.0實(shí)現(xiàn)靜態(tài)資源版本控制詳解

    Spring Boot2.0實(shí)現(xiàn)靜態(tài)資源版本控制詳解

    這篇文章主要給大家介紹了關(guān)于Spring Boot2.0實(shí)現(xiàn)靜態(tài)資源版本控制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • mybatis實(shí)現(xiàn)增刪改查_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    mybatis實(shí)現(xiàn)增刪改查_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    本文通過實(shí)例代碼給大家介紹了mybatis實(shí)現(xiàn)增刪改查功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-09-09
  • 解決@PathVariable參數(shù)接收不完整的問題

    解決@PathVariable參數(shù)接收不完整的問題

    這篇文章主要介紹了解決@PathVariable參數(shù)接收不完整的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java在OJ時(shí)運(yùn)行超時(shí)的問題解決方案

    Java在OJ時(shí)運(yùn)行超時(shí)的問題解決方案

    Java語言什么都好,就是在OJ的時(shí)候真的是太慢了,今天來講解一種讓Java運(yùn)行速度快速提高的方法,感興趣的朋友一起看看吧
    2023-11-11
  • springboot中@component注解的使用實(shí)例

    springboot中@component注解的使用實(shí)例

    這篇文章主要介紹了springboot中@component注解的使用實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例

    Java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例

    這篇文章主要介紹了java8時(shí)間轉(zhuǎn)換(LocalDateTime)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • SpringBoot多線程與任務(wù)調(diào)度總結(jié)

    SpringBoot多線程與任務(wù)調(diào)度總結(jié)

    多線程與任務(wù)調(diào)度是java開發(fā)中必須掌握的技能,本文主要介紹了SpringBoot多線程與任務(wù)調(diào)度總結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • java awt實(shí)現(xiàn)計(jì)算器功能

    java awt實(shí)現(xiàn)計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了java awt實(shí)現(xiàn)計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12

最新評(píng)論