集合框架-HashMap集合的案例
(5)HashMap集合的練習
A:HashMap<String,String>
package cn.itcast_02;
import java.util.HashMap;
import java.util.Set;
/*
* HashMap:是基於雜湊表的Map介面實現。
* 雜湊表的作用是用來保證鍵的唯一性的。
*
* HashMap<String,String>
* 鍵:String
* 值:String
*/
public class HashMapDemo {
public static void main(String[] args) {
// 建立集合物件
HashMap<String, String> hm = new HashMap<String, String>();
// 建立元素並新增元素,這樣新增寫可以,但是一般還是按下面的寫法
// String key1 = "it001";
// String value1 = "馬雲";
// hm.put(key1, value1);
hm.put("it001", "馬雲");
hm.put("it003", "馬化騰");
hm.put("it004", "賈伯斯");
hm.put("it005", "張朝陽");
hm.put("it002", "裘伯君"); // 一個人開發了wps,第一代程式設計師
hm.put("it001", "比爾蓋茲");
//加了比爾蓋茲,馬雲就被替換了
//因為鍵是唯一的,String重寫了hashcode()和equals()
// 遍歷
Set<String> set = hm.keySet();
for (String key : set) {
String value = hm.get(key);
System.out.println(key + "---" + value);
}
}
}
B:HashMap<Integer,String>
package cn.itcast_02;
import java.util.HashMap;
import java.util.Set;
/*
* HashMap<Integer,String>
* 鍵:Integer
* 值:String
*/
public class HashMapDemo2 {
public static void main(String[] args) {
// 建立集合物件
HashMap<Integer, String> hm = new HashMap<Integer, String>();
// 建立元素並新增元素
// Integer i = new Integer(27);
// Integer i = 27;
// String s = "林青霞";
// hm.put(i, s);
hm.put(27, "林青霞");
hm.put(30, "風清揚");
hm.put(28, "劉意");
hm.put(29, "林青霞");
// 下面的寫法是八進位制,但是不能出現8以上的單個資料
// hm.put(003, "hello");
// hm.put(006, "hello");
// hm.put(007, "hello");
// hm.put(008, "hello");
// 遍歷
Set<Integer> set = hm.keySet();
for (Integer key : set) {
String value = hm.get(key);
System.out.println(key + "---" + value);
}
// 下面這種方式僅僅是集合的元素的字串表示.不是遍歷
// System.out.println("hm:" + hm);
}
}
C:HashMap<String,Student>
package cn.itcast_02;
import java.util.HashMap;
import java.util.Set;
/*
* HashMap<String,Student>
* 鍵:String 學號
* 值:Student 學生物件
*/
public class HashMapDemo3 {
public static void main(String[] args) {
// 建立集合物件
HashMap<String, Student> hm = new HashMap<String, Student>();
// 建立學生物件
Student s1 = new Student("周星馳", 58);
Student s2 = new Student("劉德華", 55);
Student s3 = new Student("梁朝偉", 54);
Student s4 = new Student("劉嘉玲", 50);
// 新增元素
hm.put("9527", s1);
hm.put("9522", s2);
hm.put("9524", s3);
hm.put("9529", s4);
// 遍歷
Set<String> set = hm.keySet();
for (String key : set) {
// 注意了:這次值不是字串了
// String value = hm.get(key);
Student value = hm.get(key);
System.out.println(key + "---" + value.getName() + "---"+ value.getAge());
}
}
}
-----------------------------------------------------------------------------------------------------------------------------------------
D:HashMap<Student,String>
package cn.itcast_02;
import java.util.HashMap;
import java.util.Set;
/*
* HashMap<Student,String>
* 鍵:Student
* 要求:如果兩個物件的成員變數值都相同,則為同一個物件。
* 值:String
*/
public class HashMapDemo4 {
public static void main(String[] args) {
// 建立集合物件
HashMap<Student, String> hm = new HashMap<Student, String>();
// 建立學生物件
Student s1 = new Student("貂蟬", 27);
Student s2 = new Student("王昭君", 30);
Student s3 = new Student("西施", 33);
Student s4 = new Student("楊玉環", 35);
Student s5 = new Student("貂蟬", 27);
// 新增元素
hm.put(s1, "8888");
hm.put(s2, "6666");
hm.put(s3, "5555");
hm.put(s4, "7777");
hm.put(s5, "9999");
// 遍歷
Set<Student> set = hm.keySet();
for (Student key : set) {
String value = hm.get(key);
System.out.println(key.getName() + "---" + key.getAge() + "---"+ value);
}
}
}
package cn.itcast_02;
public class Student {
private String name;
private int age;
public Student() {
super();
}
public Student(String name, int age) {
super();
this.name = name;
this.age = 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 int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
//因為鍵相同,值覆蓋,鍵的底層依賴hashcode和equals,注意要重寫equals
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Student other = (Student) obj;
if (age != other.age)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
}
相關文章
- 集合框架-HashMap&HashSet&LinkedHshMap框架HashMap
- java集合框架--HashMap--putJava框架HashMap
- Java集合:HashMapJavaHashMap
- Java集合之HashMapJavaHashMap
- 5、Map集合——HashMapHashMap
- Java集合系列之---HashMapJavaHashMap
- 如何遍歷HashMap集合?HashMap
- 集合框架原始碼學習之HashMap(JDK1.8)框架原始碼HashMapJDK
- 集合框架框架
- Java集合——深入理解HashMapJavaHashMap
- Java集合——HashMap(jdk1.7)JavaHashMapJDK
- Java集合——HashMap(jdk1.8)JavaHashMapJDK
- java集合初探(一):HashMap.JavaHashMap
- HashMap與LinkedHashMap型別集合HashMap型別
- java進階(29)--HashMap集合JavaHashMap
- java集合框架Java框架
- Java 集合框架Java框架
- 【Java集合原始碼剖析】Java集合框架Java原始碼框架
- 【JAVA集合】JAVA集合框架及其常用方法Java框架
- 集合類HashMap,HashTable,ConcurrentHashMap區別?HashMap
- 深度解析HashMap集合底層原理HashMap
- java集合原始碼分析(六):HashMapJava原始碼HashMap
- 10.集合框架框架
- Java集合中的框架2Java框架
- Java集合原始碼學習(5)HashMapJava原始碼HashMap
- Java集合(6)之 HashMap 原始碼解析JavaHashMap原始碼
- 帶你走進Java集合之HashMapJavaHashMap
- 【java】【集合】set集合、唯一性保證、Linkset、案例Java
- 集合------集合框架Collection/Iterator迭代器/增強for迴圈框架
- 集合框架體系概述框架
- 集合框架能否存null框架Null
- Java基礎-集合框架Java框架
- JAVA集合框架 - Map介面Java框架
- Java集合框架隨筆Java框架
- Java集合框架學習Java框架
- Java集合框架(一)-ArrayListJava框架
- 集合框架2- ArrayList框架
- Java之HashMap集合簡介及遍歷JavaHashMap
- 死磕 java集合之HashMap原始碼分析JavaHashMap原始碼