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

Java常用集合之Set和Map的用法詳解

 更新時(shí)間:2022年07月06日 08:45:12   作者:愚生淺末  
這篇文章將通過(guò)一些示例為大家詳細(xì)介紹一下Java常用集合中Set和Map的用法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

常用Set集合

Set集合的特點(diǎn)

? Set接口下的集合都會(huì)有以下特點(diǎn)

  • 不能存儲(chǔ)重復(fù)元素
  • 沒(méi)有索引

HashSet

HashSet集合的特點(diǎn)

  • 底層數(shù)據(jù)結(jié)構(gòu)是哈希表
  • 存儲(chǔ)元素的順序和遍歷獲取出來(lái)的順序可能不一致
  • 沒(méi)有索引
  • 集合中不能存儲(chǔ)重復(fù)元素

創(chuàng)建對(duì)象

HashSet<元素?cái)?shù)據(jù)類型> set = new HashSet<>();

public static void main(String[] args) {
    HashSet<String> set = new HashSet<>();
}

常用方法

方法解釋
boolean add(E e)添加元素,如果元素添加不成功 返回值代表是否添加成功
boolean remove(Object o)刪除元素 ,返回值代表刪除元素是否成功
boolean contains(Object o)判斷元素是否存在
int size()獲取集合的大小
 public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        //添加元素
        boolean f = set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        System.out.println(f);
    }

我們打斷點(diǎn)調(diào)試一下:

可以看到愚生淺末四個(gè)字符已經(jīng)裝入set,且f為true證明添加成功。

我們?cè)僭囋噭h除:

public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        //添加元素
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        boolean f = set.remove("生");
    }

可以看到set已經(jīng)沒(méi)有生了,且f為true代表刪除成功。

判斷是否存在:

 public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        //添加元素
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        boolean f = set.contains("末");
    }

末是存在于set的,所以返回值為true。

獲取集合的大?。?/p>

 public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        //添加元素
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
         //獲取集合的大小
        int size = set.size();

添加了愚生淺末四個(gè)字符,所以可以得到size是4.

遍歷

1.轉(zhuǎn)換為數(shù)組遍歷

 public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        String[] strings = set.toArray(new String[0]);
        for (int i = 0; i < strings.length; i++) {
            System.out.println(strings[i]);
        }
    }

結(jié)果:

前面說(shuō)過(guò):存儲(chǔ)元素的順序和遍歷獲取出來(lái)的順序可能不一致。

2.使用迭代器遍歷

    public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        Iterator<String> it = set.iterator();
        while (it.hasNext()){
            String s = it.next();
            System.out.println(s);
        }
    }

結(jié)果:

3.foreach遍歷

 public static void main(String[] args) {
        HashSet<String> set = new HashSet<>();
        set.add("愚");
        set.add("生");
        set.add("淺");
        set.add("末");
        for (String s : set) {
            System.out.println(s);
        }
    }

結(jié)果:

常用Map集合

Map集合的概述

Map接口是雙列集合的頂層接口,下面是Map接口的定義

interface Map<K,V> K:鍵的類型;V:值的類型

? 存儲(chǔ)的數(shù)據(jù)必須包含key和value。

? key和value在Map集合中是一一對(duì)應(yīng)的關(guān)系。一個(gè)key對(duì)應(yīng)一個(gè)value。

? key在map集合中是不會(huì)重復(fù)的。

HashMap

HashMap集合的特點(diǎn)

  • 底層數(shù)據(jù)結(jié)構(gòu)是哈希表
  • 存儲(chǔ)元素的順序和遍歷獲取出來(lái)的順序可能不一致
  • key不會(huì)重復(fù)

創(chuàng)建對(duì)象

HashMap<key的數(shù)據(jù)類型,value的數(shù)據(jù)類型> map = new HashMap<>();

例如:

    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
        HashMap<String,Integer> map = new HashMap<>();
    }

常用方法

方法解釋
V put(K key, V value)添加元素,如果key不存在就添加,如果key
V get(Object key)根據(jù)key獲取對(duì)應(yīng)的value值返回。如果key不存在就返回null
V remove(Object key)根據(jù)key刪除map中對(duì)應(yīng)的鍵值對(duì)。并且把刪除的value返回
boolean containsKey(Object key)判斷key是否存在
int size()集合中鍵值對(duì)的對(duì)數(shù)
void clear()清空集合中的所有鍵值對(duì)
    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
//        map.put()
        //添加元素
        map.put("name", "愷龍");
        map.put("age", "20");
        String v = map.put("name", "愚生淺末");//將原來(lái)的愷龍?zhí)鎿Q為愚生淺末
        String name = map.get("name");//獲取名字:愷龍
        String age = map.get("age");//獲取age:20
        //刪除元素
        String delV = map.remove("age");//返回值為20
        //判斷key是否存在
        if(map.containsKey("name")){
            String agea = map.get("name");//null
            System.out.println(agea.length());
        }
        //size
        int size = map.size();
        map.clear();
    }

遍歷

1.使用entrySet遍歷

map集合的entrySet方法可以獲取一個(gè)Set集合,集合中存放的是Entry對(duì)象,一個(gè)Entry對(duì)象相當(dāng)于一個(gè)鍵值對(duì)。我們可以遍歷set集合拿到Entry對(duì)象,然后獲取出里面的鍵和值。

使用迭代器遍歷entrySet

    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
        map.put("name","愷龍");
        map.put("age","20");
        Set<Map.Entry<String, String>> entries = map.entrySet();
        //使用迭代器遍歷entrySet
        Iterator<Map.Entry<String, String>> it = entries.iterator();
        while (it.hasNext()){
            Map.Entry<String, String> entry = it.next();
            System.out.println(entry.getKey()+"="+entry.getValue());
        }
    }

結(jié)果:

使用foreach遍歷entrySet

    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
        map.put("name","愷龍");
        map.put("age","20");
        Set<Map.Entry<String, String>> entries = map.entrySet();
        //使用foreach遍歷entrySet
        for (Map.Entry<String, String> entry : entries) {
            System.out.println(entry.getKey()+"="+entry.getValue());
        }
    }

結(jié)果:

2.使用keySet遍歷

map集合的keySet方法可以獲取一個(gè)Set集合,集合中存放的是所有的key。我們可以遍歷set集合拿到key對(duì)象,然后通過(guò)key獲取對(duì)應(yīng)的value。

    public static void main(String[] args) {
        HashMap<String,String> map = new HashMap<>();
        map.put("name","愷龍");
        map.put("age","20");
        Set<String> keys = map.keySet();
        for (String key : keys) {
            System.out.println(key+"="+map.get(key));
        }
    }

結(jié)果:

HashMap的key去重原理

?HashMap在添加元素的時(shí)候會(huì)判斷集合中是否有key和本次存入的key相同。判斷的時(shí)候主要是通過(guò)hashCode方法和equals方法來(lái)進(jìn)行判斷的。hashCode相同,并且equals判斷也相同就會(huì)認(rèn)為是同一個(gè)key。

?所以如果我們要存儲(chǔ)到HashMap中的key是一個(gè)自定義的類型。就需要根據(jù)情況判斷下是否需要重寫下hashCode方法和equals方法。重寫的時(shí)候使用IDEA的提示即可。

public class Student {
    private int age;
    private String name;
    public String getName(){
        return name = this.name;
    }
    public void setName(String name){
        this.name = name;
    }
    public int getAge(){
        return age = this.age;
    }
    public void setAge(int age){
        this.age = age;
    }

    @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(age, name);
    }
}

注意:HashSet存儲(chǔ)數(shù)據(jù)其實(shí)也是使用了HashMap。所以如果往HashSet中存儲(chǔ)自定義對(duì)象也要看情況是否需要重寫hashCode方法和equals方法。

以上就是Java常用集合之Set和Map的用法詳解的詳細(xì)內(nèi)容,更多關(guān)于Java Set Map集合的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章

相關(guān)文章

  • SpringMvc微信支付回調(diào)示例代碼

    SpringMvc微信支付回調(diào)示例代碼

    微信一直是一個(gè)比較熱門的詞匯,今天這篇文章主要介紹的是SpringMvc微信支付回調(diào)的示例代碼,對(duì)大家開(kāi)發(fā)微信支付具有一定的參考借鑒價(jià)值,下面來(lái)一起看看吧。
    2016-09-09
  • Java設(shè)計(jì)模式七大原則之單一職責(zé)原則詳解

    Java設(shè)計(jì)模式七大原則之單一職責(zé)原則詳解

    單一職責(zé)原則(Single Responsibility Principle, SRP),有且僅有一個(gè)原因引起類的變更。簡(jiǎn)單來(lái)說(shuō),就是針對(duì)一個(gè)java類,它應(yīng)該只負(fù)責(zé)一項(xiàng)職責(zé)。本文將詳細(xì)介紹一下Java設(shè)計(jì)模式七大原則之一的單一職責(zé)原則,需要的可以參考一下
    2022-02-02
  • spring boot aop 記錄方法執(zhí)行時(shí)間代碼示例

    spring boot aop 記錄方法執(zhí)行時(shí)間代碼示例

    這篇文章主要介紹了spring boot aop 記錄方法執(zhí)行時(shí)間代碼示例,分享了相關(guān)代碼,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • MyBatis動(dòng)態(tài)SQL標(biāo)簽的用法詳解

    MyBatis動(dòng)態(tài)SQL標(biāo)簽的用法詳解

    這篇文章主要介紹了MyBatis動(dòng)態(tài)SQL標(biāo)簽的用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • java多線程數(shù)據(jù)分頁(yè)處理實(shí)例講解

    java多線程數(shù)據(jù)分頁(yè)處理實(shí)例講解

    在本篇內(nèi)容里小編給大家分享了一篇關(guān)于java多線程數(shù)據(jù)分頁(yè)處理實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-01-01
  • java實(shí)現(xiàn)無(wú)符號(hào)數(shù)轉(zhuǎn)換、字符串補(bǔ)齊、md5、uuid、隨機(jī)數(shù)示例

    java實(shí)現(xiàn)無(wú)符號(hào)數(shù)轉(zhuǎn)換、字符串補(bǔ)齊、md5、uuid、隨機(jī)數(shù)示例

    這篇文章主要介紹了java實(shí)現(xiàn)無(wú)符號(hào)數(shù)轉(zhuǎn)換、字符串補(bǔ)齊、md5、uuid、隨機(jī)數(shù)示例,需要的朋友可以參考下
    2014-04-04
  • 基于SpringBoot制作一個(gè)PDF切圖小工具

    基于SpringBoot制作一個(gè)PDF切圖小工具

    這篇文章主要為大家詳細(xì)介紹了如何基于SpringBoot制作一個(gè)PDF切圖小工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • Spring Boot JPA如何把ORM統(tǒng)一起來(lái)

    Spring Boot JPA如何把ORM統(tǒng)一起來(lái)

    Spring Data JPA 是 Spring 基于 ORM 框架、JPA 規(guī)范的基礎(chǔ)上封裝的一套JPA應(yīng)用框架,可使開(kāi)發(fā)者用極簡(jiǎn)的代碼即可實(shí)現(xiàn)對(duì)數(shù)據(jù)的訪問(wèn)和操作,本文給大家詳細(xì)介紹了Spring Boot JPA如何把ORM統(tǒng)一起來(lái),感興趣的朋友一起看看吧
    2018-04-04
  • Intellij IDEA安裝lombok插件及使用詳解

    Intellij IDEA安裝lombok插件及使用詳解

    今天小編就為大家分享一篇關(guān)于Intellij IDEA安裝lombok插件及使用詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • 在controller中如何設(shè)置接收參數(shù)的默認(rèn)值

    在controller中如何設(shè)置接收參數(shù)的默認(rèn)值

    這篇文章主要介紹了在controller中如何設(shè)置接收參數(shù)的默認(rèn)值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評(píng)論