之前的Map操作中key值的內容不能重復,如果重復的話,后面的內容會把前面的內容覆蓋掉。
程序范例:
import java.util.IdentityHashMap ;
import java.util.HashMap ;
import java.util.Set ;
import java.util.Iterator ;
import java.util.Map ;
class Person{
private String name ;
private int age ;
public Person(String name,int age){
this.name = name ;
this.age = age ;
}
public boolean equals(Object obj){
if(this==obj){
return true ;
}
if(!(obj instanceof Person)){
return false ;
}
Person p = (Person)obj ;
if(this.name.equals(p.name)&&this.age==p.age){
return true ;
}else{
return false ;
}
}
public int hashCode(){
return this.name.hashCode() * this.age ;
}
public String toString(){
return "姓名:" + this.name + ",年齡:" + this.age ;
}
};
public class IdentityHashMapDemo01{
public static void main(String args[]){
Map<Person,String> map = null ; // 聲明Map對象
map = new HashMap<Person,String>() ;
map.put(new Person("張三",30),"zhangsan_1") ; // 加入內容
map.put(new Person("張三",30),"zhangsan_2") ; // 加入內容
map.put(new Person("李四",31),"lisi") ; // 加入內容
Set<Map.Entry<Person,String>> allSet = null ; // 准備使用Set接收全部內容
allSet = map.entrySet() ;
Iterator<Map.Entry<Person,String>> iter = null ;
iter = allSet.iterator() ;
while(iter.hasNext()){
Map.Entry<Person,String> me = iter.next() ;
System.out.println(me.getKey() + " --> " + me.getValue()) ;
}
}
};
程序運行結果:
姓名:李四;年齡:31-->lisi
姓名:張三;年齡:30-->zhangsan_2 //根據程序運行結果可以發現,重復的key的內容將前面第一個key的內容給覆蓋了
只要地址不相等(key1!=key2),就可以利用IdentityHashMap來實現將不重復地址的key,但是內容是一樣的key添加到集合中去。
對象內容一樣但是地址不同,這是由於在實例化的過程中都是用new這個關鍵字(每次使用new這個關鍵字,vm都會給其分配一個內存空間),所以可以實現地址不同但是內容一樣