博客名称 |
---|
Java-(中级) |
Map-HashMap
HashMap:是基于哈希表的Map接口实现。
哈希表的作用是用来保证键的唯一性的,哈希表底层要依赖hashCode()和equals()方法
HashMap<String,String>
键:String
值:String
HashMap集合遍历练习
需求1:HashMap<String,String>
键:String
值:String
HashMap集合的数据结构只对键有效,数据结构是哈希表,哈希表底层依赖两个方法hashCode()和equals()方法。键的类型String已经重写了,hashCode()和equals()方法所以不同去管。
代码演示
public class MapDemo {
public static void main(String[] args) {
//创建集合
HashMap<String,String> hm = new HashMap<String,String>();
//添加元素
hm.put("it001", "马云");
hm.put("it003", "马化腾");
hm.put("it004", "乔布斯");
hm.put("it005", "张朝阳");
hm.put("it002", "裘伯君");
hm.put("it001", "比尔盖茨");
//方式1:获取键集合遍历
for (String key:hm.keySet()){
System.out.println(key+"----"+hm.get(key));
}
System.out.println("-----------------------------");
//方式2:遍历键值对对象集合
for(Map.Entry<String, String> me:hm.entrySet()){
System.out.println(me.getKey()+"----"+me.getValue());
}
}
}
结果:
--乔布斯
it003----马化腾
it005----张朝阳
it002----裘伯君
it001----比尔盖茨
-----------------------------
it004----乔布斯
it003----马化腾
it005----张朝阳
it002----裘伯君
it001----比尔盖茨
需求2:HasnMap<String,String>
键:Integer
值:String
HashMap集合的数据结构只对键有效,数据结构是哈希表,哈希表底层依赖两个方法hashCode()和equals()方法。键的类型Integer已经重写了,hashCode()和equals()方法所以不同去管。
public class MapDemo02 {
public static void main(String[] args) {
//创建集合
HashMap<Integer,String> hm = new HashMap<>();
//添加元素
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");
//方式1:获取键集合遍历
for(Integer key:hm.keySet()){
System.out.println(key+"----"+hm.get(key));
}
System.out.println("------------------");
//方式2:获取键值对对象遍历
for(Map.Entry<Integer, String> me:hm.entrySet()){
System.out.println(me.getKey()+"----"+me.getValue());
}
}
}
结果:
27----林青霞
28----刘意
29----林青霞
30----风清扬
------------------
27----林青霞
28----刘意
29----林青霞
30----风清扬
需求3:HashMap<String,Student>
键:String 学号
值:Student 学生对象
HashMap集合的数据结构只对键有效,数据结构是哈希表,哈希表底层依赖两个方法hashCode()和equals()方法。键的类型String已经重写了,hashCode()和equals()方法所以不同去管。
public class MapDemo03 {
public static void main(String[] args) {
HashMap<Integer,Student> hm = new HashMap<>();
//创建学生对象
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(9526,s1);
hm.put(9525,s1);
hm.put(9524,s1);
//方式1:获取键集合遍历
for(Integer key:hm.keySet()){
System.out.println(key+"----"+hm.get(key));
}
System.out.println("---------------------");
//方式2:获取键值对对象遍历
for(Map.Entry<Integer, Student> me:hm.entrySet()){
System.out.println(me.getKey()+"----"+me.getValue());
}
}
}
结果:
9524----Student{name='刘德华', age=55}
9525----Student{name='刘德华', age=55}
9526----Student{name='刘德华', age=55}
9527----Student{name='周星驰', age=58}
---------------------
9524----Student{name='刘德华', age=55}
9525----Student{name='刘德华', age=55}
9526----Student{name='刘德华', age=55}
9527----Student{name='周星驰', age=58}
需求4:HashMap<Student,String>
键:Student
要求:如果两个对象的成员变量值都相同,则为同一个对象。
值:String
HashMap集合的数据结构只对键有效,数据结构是哈希表,哈希表底层依赖两个方法hashCode()和equals()方法。键的类型是自定义对象所以要重写hashCode()和equals()方法。
public class MapDemo04 {
public static void main(String[] args) {
//创建集合
HashMap<Student,String> hm = new HashMap<>();
// 创建学生对象
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,"9999");
hm.put(s2,"8888");
hm.put(s3,"7777");
hm.put(s4,"6666");
hm.put(s5,"5555");
//方式1:获取键集合遍历
for(Student key:hm.keySet()){
System.out.println(key.getName()+"--"+key.getAge()+"--"+hm.get(key));
}
System.out.println("-------------------------------");
//方式2:获取键值对对象集合遍历
for(Map.Entry<Student,String> me:hm.entrySet()){
Student studentKey = me.getKey();
System.out.println(studentKey.getName()+"----"+studentKey.getAge()+"----"+me.getValue());
}
}
}
结果:去重复
西施--33--7777
杨玉环--35--6666
王昭君--30--8888
貂蝉--27--5555
-------------------------------
西施----33----7777
杨玉环----35----6666
王昭君----30----8888
貂蝉----27----5555