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集合の遍歴方式
実行結果:
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); } }}
実行結果:
実行結果:
転載先:https://www.cnblogs.com/sx-jd/p/9950096.html
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