JAVA基礎學習-集合三-Map、HashMap,TreeMap與經常使用API

Fork me on GitHub

JAVA基礎學習day16--集合三-Map、HashMap,TreeMap與經常使用API

 

1、Map簡述

1.一、簡述html

public interface Map<K,V>
類型參數:
K - 此映射所維護的鍵的類型 key
V - 映射值的類型 value
該集合提供鍵--值的映射。key不能重複,一對對的存儲方式

將鍵映射到值的對象。一個映射不能包含重複的鍵;每一個鍵最多隻能映射到一個值。java

1.二、方法git

嵌套類摘要
static interface Map.Entry<K,V> 
映射項(鍵-值對)。

 

方法摘要
void clear() 
今後映射中移除全部映射關係(可選操做)。
boolean containsKey(Object key) 
若是此映射包含指定鍵的映射關係,則返回 true
boolean containsValue(Object value) 
若是此映射將一個或多個鍵映射到指定值,則返回 true
Set<Map.Entry<K,V>> entrySet() 
返回此映射中包含的映射關係的 Set 視圖。
boolean equals(Object o) 
比較指定的對象與此映射是否相等。
V get(Object key) 
返回指定鍵所映射的值;若是此映射不包含該鍵的映射關係,則返回 null
int hashCode() 
返回此映射的哈希碼值。
boolean isEmpty() 
若是此映射未包含鍵-值映射關係,則返回 true
Set<K> keySet() 
返回此映射中包含的鍵的 Set 視圖。
V put(K key, V value) 
將指定的值與此映射中的指定鍵關聯(可選操做)。
void putAll(Map<? extends K,? extends V> m) 
從指定映射中將全部映射關係複製到此映射中(可選操做)。
V remove(Object key) 
若是存在一個鍵的映射關係,則將其今後映射中移除(可選操做)。
int size() 
返回此映射中的鍵-值映射關係數。
Collection<V> values() 
返回此映射中包含的值的 Collection 視圖。

 1.三、經常使用子類github

HashTable:底層是哈希表,不能夠存入Null鍵Null值,線程是同步的JDK1.0效率低web

HashMap:基於哈希表數據結構。容許使用Null鍵Null值,但只有一個Null鍵,線程非同步的。JDK1.2效率高正則表達式

TreeMap:二叉樹,線程不一樣步。能夠用於給Map集中的key鍵進行排序。算法

和Sety集合很像,Set底層就是Map集合。sql

1.四、Putwindows

添加元素,添加相同的鍵,那麼後添加的值會覆蓋的Vaule,put方法會返回被覆蓋的值。數組

 

 

 

2、HashMap

2.一、經常使用方法

 

複製代碼
package com.pb.map.demo1;

import java.util.HashMap;
import java.util.Map;

public class MapDemo1 {

    public static void main(String[] args) {
        Map<String,String> map=new HashMap<String,String>();
        //添加
        map.put("01", "zhangsan");
        System.out.println(map.put("01", "lisi002"));//zhangsan
        map.put("02", "wangwu03");
        map.put("03", "wangwu04");
        map.put(null, "ffff");
        map.put("04", "qqquqq");
        //判斷有沒有key
        System.out.println(map.containsKey("02"));//true
        //判斷 有這有 這個value
        System.out.println(map.containsValue("ffff"));//true
        //獲取
        System.out.println(map.get("03"));//wangwu04
        System.out.println(map.get(null));//ffff
        System.out.println(map.get("fdsfdsf"));//null
        System.out.println(map.remove("02"));//返回value的值
        System.out.println(map.remove("0fdsfd"));//沒有就返回null
        System.out.println(map);//{null=ffff, 01=lisi002, 03=wangwu04, 04=qqquqq} 是無序的
    }

}
複製代碼

 

 

2.二、key和values

keySet:將map中全部的鍵 存入到Set集合。由於set具有迭代器。返回爲set集合

          能夠迭代方式取出全部的鍵,在根據get方法,獲取每個鍵對應的值。

 

複製代碼
package com.pb.map.demo1;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

public class MapDemo2 {

    public static void main(String[] args) {
        Map<String,String> map=new HashMap<String,String>();
            //添加
                map.put("09", "zhaoliu");    
                map.put("01", "zhangsan");            
                map.put("02", "wangwu03");
                map.put("03", "wangwu04");
                map.put("04", "qqquqq");
                //獲取map集合中的全部鍵的集合
                Set<String> keySet=map.keySet();
                //迭代全部鍵來獲取值
                Iterator<String> iterator=keySet.iterator();
                while(iterator.hasNext()){
                    String key=iterator.next();
                    //經過map.get(鍵)的方式來獲取值
                    System.out.println(key+".........."+map.get(key));
                }
    }

}
複製代碼

 

 

entrySet:返回爲Set<Map.Entry<k,v>> entrySet:將Map集合中的映射關係存入到Set 集合中,而這個關係的數據類型就是Map.Entry

 

Map.entrySet()

 


 

 

 

方法摘要
boolean equals(Object o) 
比較指定對象與此項的相等性。
K getKey() 
返回與此項對應的鍵。
V getValue() 
返回與此項對應的值。
int hashCode() 
返回此映射項的哈希碼值。
V setValue(V value) 
用指定的值替換與此項對應的值(可選操做)。

 

複製代碼
package com.pb.map.demo2;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

/**
 * 學生屬性:姓名,年齡
 * 注意姓名和年齡相同的視爲同一個學生
 * 1.描述學生
 * 2.定義map容器,將學生作爲鍵,地址做爲值、值入
 * 3.獲取map集合的元素
 */

//學生類
class Student implements Comparable<Student>{
    private String name;
    private int age;
    
    //讓對象自己具有比較性
    @Override
    public int compareTo(Student s){
        int num=new Integer(this.age).compareTo(new Integer(s.age));
        if(num==0){
            return this.name.compareTo(s.name);
        }
        return num;
    }
    
    /*
     * 重寫hash
     */
    @Override
    public int hashCode(){
        return name.hashCode()+age*33;
    }
    /*
     * 重寫equals
     */
    @Override
    public boolean equals(Object obj){
        if(!(obj instanceof Student)){
            throw new ClassCastException("類型不匹配");
        }
        Student stu=(Student)obj;
        return this.name.equals(stu.name)&&this.age==stu.age;
        
    }
    
    public Student() {
        super();
    }
    public Student(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public void show(){
        System.out.println(this.name+"...."+this.age);
    }
    
}
public class MapTest {

    public static void main(String[] args) {
        Map<Student,String> map=new HashMap<Student,String>();
        map.put(new Student("lisi01",21), "北京");
        map.put(new Student("lisi01",21), "上海");//覆蓋第一個值
        map.put(new Student("lisi02",23), "深圳");
        map.put(new Student("lisi04",22), "武漢");
        map.put(new Student("lisi03",24), "天津");
        System.out.println("======keySet方法======");
        //第一種遍歷方式
        Set<Student> keySet=map.keySet();
        Iterator<Student> it=keySet.iterator();
        while(it.hasNext()){
            Student stu=it.next();
            String add=map.get(stu);
            System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
        }
        System.out.println("======entrySet方法======");
        //第二種遍歷方式
        Set<Map.Entry<Student, String>> entrySet=map.entrySet();
        Iterator<Map.Entry<Student, String>> iter=entrySet.iterator();
        while(iter.hasNext()){
            Map.Entry<Student, String> student=iter.next();
            Student stu=student.getKey();
            String add=student.getValue();
            System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
        }
    }

}
複製代碼
複製代碼
======keySet方法======
lisi01...21....上海
lisi02...23....深圳
lisi04...22....武漢
lisi03...24....天津
======entrySet方法======
lisi01...21....上海
lisi02...23....深圳
lisi04...22....武漢
lisi03...24....天津
複製代碼

 

 

 

 

3、TreeMap

3.一、TreeMap排序

 

複製代碼
package com.pb.map.demo2;

import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

/**
 * 學生屬性:姓名,年齡
 * 注意姓名和年齡相同的視爲同一個學生
 * 1.描述學生
 * 2.定義map容器,將學生作爲鍵,地址做爲值、值入,
 * 3.對學生排序按姓名排序
 * 3.獲取map集合的元素
 * 
 */

//學生類
class Student implements Comparable<Student>{
    private String name;
    private int age;
    
    //讓對象自己具有比較性
    @Override
    public int compareTo(Student s){
        int num=new Integer(this.age).compareTo(new Integer(s.age));
        if(num==0){
            return this.name.compareTo(s.name);
        }
        return num;
    }
    
    /*
     * 重寫hash
     */
    @Override
    public int hashCode(){
        return name.hashCode()+age*33;
    }
    /*
     * 重寫equals
     */
    @Override
    public boolean equals(Object obj){
        if(!(obj instanceof Student)){
            throw new ClassCastException("類型不匹配");
        }
        Student stu=(Student)obj;
        return this.name.equals(stu.name)&&this.age==stu.age;
        
    }
    
    public Student() {
        super();
    }
    public Student(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public void show(){
        System.out.println(this.name+"...."+this.age);
    }
    
}
public class MapTest {

    public static void main(String[] args) {
        TreeMap<Student,String> map=new TreeMap<Student,String>(new StudentNameCom());
        
        map.put(new Student("lisi01",21), "上海");//覆蓋第一個值
        map.put(new Student("lisi02",23), "深圳");
        map.put(new Student("a",56), "北京");
        map.put(new Student("lisi04",22), "武漢");
        map.put(new Student("lisi03",24), "天津");
        map.put(new Student("a",33), "北京");
        map.put(new Student("lisi01",21), "北京");
        System.out.println("======keySet方法======");
        //第一種遍歷方式
        Set<Student> keySet=map.keySet();
        Iterator<Student> it=keySet.iterator();
        while(it.hasNext()){
            Student stu=it.next();
            String add=map.get(stu);
            System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
        }
        System.out.println("======entrySet方法======");
        //第二種遍歷方式
        Set<Map.Entry<Student, String>> entrySet=map.entrySet();
        Iterator<Map.Entry<Student, String>> iter=entrySet.iterator();
        while(iter.hasNext()){
            Map.Entry<Student, String> student=iter.next();
            Student stu=student.getKey();
            String add=student.getValue();
            System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
        }
    }

}
class StudentNameCom implements Comparator<Student>{

    @Override
    public int compare(Student stu1, Student stu2) {
        int num=stu1.getName().compareTo(stu2.getName());
        if(num==0){
            return new Integer(stu1.getAge()).compareTo(new Integer(stu2.getAge()));
        }
        return num;
    }
    
}
複製代碼

 

 

4、TreeMap使用

 

4.一、示例

 

複製代碼
package com.pb.map.demo2;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

/*
 * "sdfgzxcvasdfxcvdf"獲取該字符串中的字母出次數
 * 1.使用map集合映射
 * 2.將字符中的字母作KEY,次數作value
 */
public class MapTest2 {

    public static void main(String[] args) {
        String str = "sdfgzxcvasdfxcvdf";
        TreeMap<String, Integer> map = getCount(str);
        Set<String> keySet = map.keySet();
        Iterator<String> it = keySet.iterator();
        while (it.hasNext()) {
            String s = it.next();
            Integer count = map.get(s);
            System.out.println(s + "...." + count);
        }

        String tmp = getCount2(str);
        System.out.println(tmp);
    }

    // 第一種
    public static TreeMap<String, Integer> getCount(String str) {
        TreeMap<String, Integer> map = new TreeMap<String, Integer>();

        for (int x = 0; x < str.length(); x++) {
            Set<String> keys = map.keySet();
            String s = str.substring(x, x + 1);
            if (keys.contains(s)) {
                Integer count = map.get(s);
                map.put(s, count + 1);
            } else {
                map.put(s, 1);
            }
        }

        return map;
    }

    // 第二種
public static String getCount2(String str){
    //轉換爲字符數組
    char[] chs=str.toCharArray();
    //定義TreeMap容器來存放
    TreeMap<Character,Integer> tm=new TreeMap<Character,Integer>();
    //定義變量來存放次數
    int count=0;
    for(int x=0;x<chs.length;x++){
        if(!(chs[x]>='a' &&chs[x]<='z' || chs[x] >= 'A'&&chs[x]<='Z')){
            continue;
        }
        Integer value=tm.get(chs[x]);
        if(value!=null){
            count=value;
        }
        count++;
        tm.put(chs[x], count);
        count=0;
    }
    //聲明變長sb對象
    StringBuilder sb=new StringBuilder();
    //獲取Map.Entry對象
    Set<Map.Entry<Character, Integer>> entrySet=tm.entrySet();
    Iterator<Map.Entry<Character, Integer>> it=entrySet.iterator();
    //遍歷添加
    while(it.hasNext()){
        Map.Entry<Character, Integer> m=it.next();
        Character c=m.getKey();
        Integer value=m.getValue();
        sb.append(c+"("+value+")");
    }
    return sb.toString();
    
}
}
複製代碼

 

結果:

 

複製代碼
a....1
c....2
d....3
f....3
g....1
s....2
v....2
x....2
z....1
a(1)c(2)d(3)f(3)g(1)s(2)v(2)x(2)z(1)
複製代碼

 

 

5、Map擴展

5.一、Map中嵌套Map或者集合

 

複製代碼
package com.pb.map.demo3;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;

class Person{
    private String name;
    private int age;
    public Person() {
        super();
        // TODO Auto-generated constructor stub
    }
    public Person(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    
}
public class MapTest1 {

    public static void main(String[] args) {
        
        HashMap<String,ArrayList<Person>> map=new HashMap<String,ArrayList<Person>>();
        
        ArrayList<Person> persons1=new ArrayList<Person>();
        persons1.add(new Person("張三",33));
        persons1.add(new Person("李四",33));
        persons1.add(new Person("王五",33));
        ArrayList<Person> persons2=new ArrayList<Person>();
        persons2.add(new Person("趙六",33));
        persons2.add(new Person("錢七",33));
        persons2.add(new Person("劉八",33));
        
        
        map.put("SB001", persons1);
        map.put("SB002", persons2);
        
        
        Iterator<String> it=map.keySet().iterator();
        while(it.hasNext()){
            String room=it.next();
            System.out.println(room);
            ArrayList<Person> p=map.get(room);
            getInfos(p);
        }
        
        
    }
    
    public static void getInfos(ArrayList<Person> list){
        Iterator<Person> it=list.iterator();
        while(it.hasNext()){
            Person p=it.next();
            System.out.println(p.getName()+"..."+p.getAge());
        }
    }

}
//結果

SB001
張三...33
李四...33
王五...33
SB002
趙六...33
錢七...33
劉八...33
複製代碼

 

 
 
 from:https://www.cnblogs.com/liunanjava/p/4839634.html
相關文章
相關標籤/搜索