Mapコレクションの遍歴方法とTreeMapコレクションカスタムオブジェクトの比較を保存するComparableとComparatorの2つの方法...

20839 ワード

Map集合の特徴
1、Mapコレクションに保存されているのはキー値のペアで、キーと値は一対一に対応しています
2、1つのマッピングに重複する値を含めることはできません
3、各キーは最大1つの値にしかマッピングできない
 
MapインタフェースとCollectionインタフェースの違い
Mapは二列集合のルートインタフェースであり、Collectionは単列集合のルートインタフェースである
1、Mapは二列(二列集合のルートインタフェース)であり、Collectionは単列(単列集合のルートインタフェース)である
2、Mapのキーは一意であり、CollectionのサブインタフェースSetは一意である
3、Map集合のデータ構造値はキーに対して有効で、値と関係がない.例えば:TreeMap:キーはツリーアルゴリズム、HashMap:キーはhashアルゴリズム、Collection集合のデータ構造は要素に対して有効
 
Map集合の遍歴方式
 
package com.jd.text;

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

public class Demo06 {

    public static void main(String[] args) {
        //   map  
        Map map = new HashMap<>();
        //                    
        map.put("  ", 12);
        map.put("  ", 13);
        map.put("   ", 14);
        map.put("  ", 15);
        //
        map.remove("  ");
        // map.clear();//                  
        //      key     value
        Object obj1 = map.get("  ");
        System.out.println(obj1);
        //        key,    true,     false。
        boolean b = map.containsKey("  ");
        System.out.println(b);
        //        value,    true,     false。
        boolean c = map.containsValue(13);
        System.out.println(c);
        
        System.out.println("******************************");
        
        // map     ,  keyset()  (   )
        Set keySet = map.keySet();
        Iterator iter = keySet.iterator();
        while (iter.hasNext()) {
            Object key = iter.next();
            Object value = map.get(key);
            System.out.println(key + ":" + value);
        }
        System.out.println("******************************");
        
        // map     ,  keyset()  (foreach)
        Set keySet2 = map.keySet();
        for (Object key : keySet2) {
            Object value = map.get(key);
            System.out.println(key + ":" + value);
        }
        System.out.println("******************************");
        
        // map     ,  entrySet()  (foreach)
        Set entrySet = map.entrySet();
        for (Object obj3 : entrySet) {
            Entry e = (Entry) obj3;
            Object key = e.getKey();
            Object value = e.getValue();
            System.out.println(key + ":" + value);
        }
        System.out.println("******************************");
        
        // map   values  ,    map   value     collection  
        Collection coll = map.values();
        for (Object obj : coll) {
            System.out.println(obj);
        }
    }
}

実行結果:
12
true
true
******************************
  :13
  :12
   :14
******************************
  :13
  :12
   :14
******************************
  :13
  :12
   :14
******************************
13
12
14

 
TreeMapコレクションカスタムオブジェクトの保存
package com.jd.text;
import java.util.Set;import java.util.TreeMap;
/*TreeMapはカスタムオブジェクトを保存し、ComparableとComparatorの2つの方法を比較します*1.Comparableインタフェースを実装することで、compareTo()メソッドを書き換えます.*/public class Demo07 {
public static void main(String[]args){TreeMapmap=new TreeMap<>(); map.put(new User(「張三01」,12),11);map.put(new User(「張三01」,10),11);map.put(new User(「張三01」,10),11);map.put(new User(「張三02」,13),11);map.put(new User(「張三01」,12),11);////hashCode()とequals(Obls(Obbbbb)とequals(Obs(Obb)を書き換えることによって、////////hashCode()とequals(Obls jectobj)メソッドは、Set set=map.keySet()に重複する値が格納されないようにします.for(Object key:set){ Object value = map.get(key); System.out.println(key + ":"+ value); } }}
 
package com.jd.text;
/*
 *     Comparable  ,  compareTo()  。
 */
public class User implements Comparable{

    private String name;
    private int 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;
    }
    @Override
    public String toString() {
        return "User [name=" + name + ", age=" + age + "]";
    }
    public User(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public User() {
        super();
    }
    
    @Override
    public int hashCode() {
        final int prime=31;
        int result=1;
        result=prime*result+age;
        result=prime*result+((name==null)?0:name.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj) {
        if(this==obj)
            return true;
        if(obj==null)
            return false;
        if(getClass()!=obj.getClass())
            return false;
        User user=(User) obj;
        if(age!=user.age)
            return false;
        if(name==null){
            if(user.name!=null)
                return false;
        }else if(!name.equals(user.name))
            return false;
        return true;
    }
    @Override
    public int compareTo(Object o) {
        if(o instanceof User){
            User user=(User) o;
            int sum=name.compareTo(user.name);
            if(sum==0)
                return age-user.age;
            return sum;
        }
        throw new ClassCastException("  User  ");
    }
    
}

実行結果:
User [name=  01, age=10]:11
User [name=  01, age=12]:11
User [name=  02, age=13]:11

 
package com.jd.text;
/*
 * TreeMap       ,   Comparable Comparator    
 * 2.         Comparator  ,  compare(Object o1, Object o2)  
 */

import java.util.Comparator;
import java.util.Set;
import java.util.TreeMap;

public class Demo08 {

    public static void main(String[] args) {
        TreeMap map=new TreeMap(new MyCompare());
        map.put(new User2("  01", 12),11);
        map.put(new User2("  01", 10),11);
        map.put(new User2("  02", 13),11);
        map.put(new User2("  01", 12),11);
        //    hashCode() equals(Object obj)          
        Set set = map.keySet();
        for (Object key : set) {
            Object value = map.get(key);
            System.out.println(key + ":" + value);
        }
    }
}

class User2{
    String name;
    int age;
    
    public User2(String name,int age){
        this.name=name;
        this.age=age;
    }
    
    @Override
    public int hashCode(){
        final int prime=31;
        int result=1;
        result=prime*result+age;
        result=prime*result+((name==null)?0:name.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj){
        if(this==obj)
            return true;
        if(obj==null)
            return false;
        if(getClass()!=obj.getClass())
            return false;
        User2 u=(User2) obj;
        if(age!=u.age)
            return false;
        if(name==null){
            if(u.name!=null)
                return false;
        }else if(!name.equals(u.name))
                return false;
        return true;
    }
    @Override
    public String toString() {
        return "User2 [name=" + name + ", age=" + age + "]";
    }
}
//   
class MyCompare implements Comparator{

    @Override
    public int compare(Object o1, Object o2) {
        if(o1 instanceof User2 && o2 instanceof User2){
            User2 u1=(User2) o1;
            User2 u2=(User2) o2;
            int sum=u1.age-u2.age;
            if(sum==0){
                return u1.name.compareTo(u2.name);
            }
            return sum;
        }
        throw new ClassCastException("  User2   ");
    }
    
}

実行結果:
User2 [name=  01, age=10]:11
User2 [name=  01, age=12]:11
User2 [name=  02, age=13]:11

 
転載先:https://www.cnblogs.com/sx-jd/p/9950096.html