package com.shuzu;import java.util.HashMap;import java.util.Iterator;public class HashMapTest { public static void main(String[] args) { // TODO Auto-generated method stub Student s1 = new Student("小明",25); Student s2 = new Student("小剛",24); Student s3 = new Student("小胖",23); HashMap hm = new HashMap(); hm.put("小明", s1); hm.put("小剛", s2); hm.put("小強", s3); //1.取出信息 if(hm.containsKey("小明")){ System.out.PRintln("有該學生!"); Student st = (Student) hm.get("小明"); System.out.println("姓名:"+st.getName()+" 年齡:"+st.getAge()); }else { System.out.println("沒有該學生!"); } //2.利用 Iterator ,遍歷 HashMap Iterator it = hm.keySet().iterator(); while(it.hasNext()){ String key = it.next().toString(); //上一步得到 “Key”,現在取出對象 Student st = (Student) hm.get(key); System.out.println("找到學生:"+st.getName()+" 年齡:"+st.getAge()); } }}class Student{ private String name; 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; } private int age; public Student(String name, int age) { super(); this.name = name; this.age = age; } }注意:
1、HashMap 如果在同一個“Key“上添加不同的”object“,HM會默認后者 覆蓋前者。
hm.put("小明", s1); hm.put("小剛", s2); hm.put("小明", s3);如上Code,第三行s3將覆蓋s1 。 即HashMap中的Key,Value是一一對應的關系。2、遍歷HashMap 時使用 Iterator 。3、HashMap在遍歷時,并不是按照添加的前后順序輸出的! 輸出順序到底是什么規律呢?
4、Hashtable 與HashMap 在使用的”存取、遍歷“等方法上幾乎一致!! 其區別主要在于”線程同步“與否。
新聞熱點
疑難解答