亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

新手初學(xué)Java-Map

 更新時間:2021年07月07日 15:58:26   作者:N0lan  
Map簡介:將鍵映射到值的對象。一個映射不能包含重復(fù)的鍵;每個鍵最多只能映射到一個值。此接口取代 Dictionary 類,后者完全是一個抽象類,而不是一個接口

Map

Map是一種依照鍵(key)存儲元素的容器,鍵(key)很像下標,在List中下標是整數(shù)。在Map中鍵(key)可以使任意類型的對象。Map中不能有重復(fù)的鍵(Key),每個鍵(key)都有一個對應(yīng)的值(value)。

一個鍵(key)和它對應(yīng)的值構(gòu)成map集合中的一個元素。

Map中的元素是兩個對象,一個對象作為鍵,一個對象作為值。鍵不可以重復(fù),但是值可以重復(fù)。

看頂層共性方法找子類特有對象.

Map與Collection在集合框架中屬并列存在

Map存儲的是鍵值對

Map存儲元素使用put方法,Collection使用add方法

Map集合沒有直接取出元素的方法,而是先轉(zhuǎn)成Set集合,在通過迭代獲取元素

Map集合中鍵要保證唯一性

也就是Collection是單列集合, Map 是雙列集合。

學(xué)習體系

Map學(xué)習體系:
 ---| Map  接口    將鍵映射到值的對象。一個映射不能包含重復(fù)的鍵;每個鍵最多只能映射到一個值。
            ---| HashMap  采用哈希表實現(xiàn),所以無序
            ---| TreeMap   可以對健進行排序
---|Hashtable:
底層是哈希表數(shù)據(jù)結(jié)構(gòu),線程是同步的,不可以存入null鍵,null值。
效率較低,被HashMap 替代。
---|HashMap:
底層是哈希表數(shù)據(jù)結(jié)構(gòu),線程是不同步的,可以存入null鍵,null值。
要保證鍵的唯一性,需要覆蓋hashCode方法,和equals方法。
---| LinkedHashMap:
該子類基于哈希表又融入了鏈表??梢訫ap集合進行增刪提高效率。
---|TreeMap:
底層是二叉樹數(shù)據(jù)結(jié)構(gòu)??梢詫ap集合中的鍵進行排序。需要使用Comparable或者Comparator 進行比較排序。return 0,來判斷鍵的唯一性。

常見方法

1、添加:
    1、V put(K key, V value)    (可以相同的key值,但是添加的value值會覆
蓋前面的,返回值是前一個,如果沒有就返回null)                                         
    2、putAll(Map<? extends K,? extends V> m)  從指定映射中將所有映射關(guān)
系復(fù)制到此映射中(可選操作)。
2、刪除
    1、remove()    刪除關(guān)聯(lián)對象,指定key對象
    2、clear()     清空集合對象
3、獲取
     1:value get(key); 可以用于判斷鍵是否存在的情況。當指定的鍵不存在的時候,返
回的是null。
3、判斷:
    1、boolean isEmpty()   長度為0返回true否則false
    2、boolean containsKey(Object key)  判斷集合中是否包含指定的key
3、boolean containsValue(Object value)  判斷集合中是否包含指定的value
4、長度:
Int size()

Map的操作

這里使用hashMap

map增刪查

import java.util.HashMap;
import java.util.Map;
public class Maps {
    public static void main(String[] args){
        Map<String,String> myMap=new HashMap<String,String>();
        myMap.put("N0lan","tryup");
        myMap.put("Cors","study");//add
        System.out.println(myMap);
        myMap.remove("N0lan");//delete
        System.out.println(myMap.get("Cors"));//find
        System.out.println(myMap.isEmpty());//panduan
        System.out.println(myMap.containsKey("Hello"));//
    }
}

map的遍歷

keySet遍歷

將Map轉(zhuǎn)成Set集合(keySet()),通過Set的迭代器取出Set集合中的每一個元素(Iterator)就是Map集合中的所有的鍵,再通過get方法獲取鍵對應(yīng)的值。

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class Maps {
    public static void main(String[] args){
       /* Map<String,String> myMap=new HashMap<String,String>();
        myMap.put("N0lan","tryup");
        myMap.put("Cors","study");//add
        System.out.println(myMap);
        myMap.remove("N0lan");//delete
        System.out.println(myMap.get("Cors"));//find
        System.out.println(myMap.isEmpty());//panduan
        System.out.println(myMap.containsKey("Hello"));//*/
        Bianli();
    }
    public static void Bianli(){
        Map<String,String> myMap=new HashMap<String,String>();
        myMap.put("N0lan","tryup");
        myMap.put("III","tryups");
        myMap.put("Cors","study");//add
        //
        // 獲取方法:
        // 第一種方式: 使用keySet
        // 需要分別獲取key和value,沒有面向?qū)ο蟮乃枷?
        // Set<K> keySet() 返回所有的key對象的Set集合
        Set<String> keyvaule= myMap.keySet();
        Iterator<String> keys=keyvaule.iterator();
        while(keys.hasNext()){
            String key=keys.next();
            String vaule=myMap.get(key);
            System.out.println("key=" + key + " vaule=" + vaule);
        }
    }
}

第二種方式:通過values獲取所有值,不能獲取到key對象

第三種方式: Map.Entry遍歷

面向?qū)ο蟮乃枷雽ap集合中的鍵和值映射關(guān)系打包為一個對象,就是Map.Entry,將該對象存入Set集合,Map.Entry是一個對象,那么該對象具備的getKey,getValue獲得鍵和值。

 public  static  void Entryt(){
        Map<String,String> myMap=new HashMap<String,String>();
        myMap.put("N0lan","tryup");
        myMap.put("III","tryups");
        myMap.put("Cors","study");//add
        // 返回的Map.Entry對象的Set集合 Map.Entry包含了key和value對象
        Set<Map.Entry<String,String>> ts= myMap.entrySet();
        Iterator<Map.Entry<String,String>> all=ts.iterator();
        while (all.hasNext()){
            Map.Entry<String, String> allin = all.next();
            System.out.println("key="+allin.getKey()+"  value="+allin.getValue());
        }
    }
}

HashMap案例用自定義對象作為Map的key

import sun.invoke.empty.Empty;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class SelfClass {
    public static  void main(String[] args){
        HashMap<Person,String> mymap=new HashMap<Person,String>();
        mymap.put(new Person("N0lan",99),"boy");
        mymap.put(new Person("zAD",99),"GIR");
        Set<Map.Entry<Person,String>> duixiang=mymap.entrySet();
        Iterator<Map.Entry<Person, String>> it = duixiang.iterator();
        while(it.hasNext()){
            Map.Entry<Person,String> next=it.next();
            Person key= next.getKey();
            String value = next.getValue();
            System.out.println(key + " = " + value);
        }
    }
}
class Person{
    private String name;
    private int age;
    Person(){
    }
    public Person(String name,int age){
        this.name=name;
        this.age=age;
    }
    public String getName(){
        return name;
    }
    public void Setname(String name){
        this.name=name;
    }
    @Override
    public int hashCode() {
        return this.name.hashCode() + age * 37;
    }
    @Override
    public boolean equals(Object obj) {
        if (obj instanceof Person) {
            Person p = (Person) obj;
            return this.name.equals(p.name) && this.age == p.age;
        } else {
            return false;
        }
    }
    @Override
    public String toString() {
        return "Person@name:" + this.name + " age:" + this.age;
    }
 
}

TreeMap

TreeMap的排序,TreeMap可以對集合中的鍵進行排序。如何實現(xiàn)鍵的排序?

方式一:元素自身具備比較性

和TreeSet一樣原理,需要讓存儲在鍵位置的對象實現(xiàn)Comparable接口,重寫compareTo方法,也就是讓元素自身具備比較性,這種方式叫做元素的自然排序也叫做默認排序。

方式二:容器具備比較性

當元素自身不具備比較性,或者自身具備的比較性不是所需要的。那么此時可以讓容器自身具備。需要定義一個類實現(xiàn)接口Comparator,重寫compare方法,并將該接口的子類實例對象作為參數(shù)傳遞給TreeMap集合的構(gòu)造方法。

注意:當Comparable比較方式和Comparator比較方式同時存在時,以Comparator的比較方式為主

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Spring?Boot?使用?SSE?方式向前端推送數(shù)據(jù)詳解

    Spring?Boot?使用?SSE?方式向前端推送數(shù)據(jù)詳解

    這篇文章主要介紹了Spring?Boot?使用SSE方式向前端推送數(shù)據(jù)詳解,SSE簡單的來說就是服務(wù)器主動向前端推送數(shù)據(jù)的一種技術(shù),它是單向的,也就是說前端是不能向服務(wù)器發(fā)送數(shù)據(jù)的
    2022-08-08
  • Java使用雪花算法生成唯一ID的實現(xiàn)示例

    Java使用雪花算法生成唯一ID的實現(xiàn)示例

    雪花算法是 Twitter 開源的一種分布式ID生成算法,其目的是生成全局唯一的 ID,本文主要介紹了Java使用雪花算法生成唯一ID的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • Java @Autowired注解底層原理詳細分析

    Java @Autowired注解底層原理詳細分析

    @Autowired注解可以用在類屬性,構(gòu)造函數(shù),setter方法和函數(shù)參數(shù)上,該注解可以準確地控制bean在何處如何自動裝配的過程。在默認情況下,該注解是類型驅(qū)動的注入
    2022-11-11
  • Java解決青蛙跳臺階問題流程

    Java解決青蛙跳臺階問題流程

    所謂的青蛙跳臺階問題,就是指一只青蛙一次可以跳上1級臺階,也可以跳上2級。求該青蛙跳上一個n級的臺階總共有多少種跳法。本文將用Java解決這一問題,需要的可以參考一下
    2022-03-03
  • Java實現(xiàn)單例模式的五種方法介紹

    Java實現(xiàn)單例模式的五種方法介紹

    單例模式確保某個類只有一個實例,而且自行實例化并向整個系統(tǒng)提供這個實例。在計算機系統(tǒng)中,線程池、緩存、日志對象、對話框、打印機、顯卡的驅(qū)動程序?qū)ο蟪1辉O(shè)計成單例
    2023-01-01
  • 比較java中Future與FutureTask之間的關(guān)系

    比較java中Future與FutureTask之間的關(guān)系

    在本篇文章里我們給大家分享了java中Future與FutureTask之間的關(guān)系的內(nèi)容,有需要的朋友們可以跟著學(xué)習下。
    2018-10-10
  • JavaWeb實現(xiàn)學(xué)生信息管理系統(tǒng)(3)

    JavaWeb實現(xiàn)學(xué)生信息管理系統(tǒng)(3)

    這篇文章主要為大家詳細介紹了JavaWeb實現(xiàn)學(xué)生信息管理系統(tǒng)第三篇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 詳細分析java線程wait和notify

    詳細分析java線程wait和notify

    本篇文章是對java多線程wait()和notify()進行了詳細的分析介紹,需要了解的朋友參考下
    2015-07-07
  • 基于@Valid和@Validated驗證List集合的踩坑記錄

    基于@Valid和@Validated驗證List集合的踩坑記錄

    這篇文章主要介紹了基于@Valid和@Validated驗證List集合的踩坑記錄,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 圖解Spring框架的設(shè)計理念與設(shè)計模式

    圖解Spring框架的設(shè)計理念與設(shè)計模式

    這篇文章主要通過多圖詳細解釋Spring框架的設(shè)計理念與設(shè)計模式,需要的朋友可以參考下
    2015-08-08

最新評論