key可以重復的map集合:IdentityHashMap


之前的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都會給其分配一個內存空間),所以可以實現地址不同但是內容一樣


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM