1.Map集合
1.1Map集合概述和特点【理解】1.2Map集合的基本功能【应用】1.3Map集合的获取功能【应用】1.4Map集合的遍历(方式1)【应用】1.5Map集合的遍历(方式2)【应用】1.6Map集合的遍历(方式3)【应用】 2.HashMap集合
2.1HashMap集合概述和特点【理解】2.2HashMap集合应用案例【应用】 3.TreeMap集合
3.1TreeMap集合概述和特点【理解】3.2TreeMap集合应用案例一【应用】3.3TreeMap集合应用案例二【应用】
1.Map集合 1.1Map集合概述和特点【理解】
Map集合概述
interface MapK:键的类型;V:值的类型
Map集合的特点
双列集合,一个键对应一个值键不可以重复,值可以重复键值对对象entry
Map集合的基本使用
public class MapDemo01 { public static void main(String[] args) { //创建集合对象 Map1.2Map集合的基本功能【应用】map = new HashMap (); //V put(K key, V value) 将指定的值与该映射中的指定键相关联 map.put("itheima001","林青霞"); map.put("itheima002","张曼玉"); map.put("itheima003","王祖贤"); map.put("itheima003","柳岩"); //输出集合对象 System.out.println(map); } }
方法介绍
示例代码
public class MapDemo02 { public static void main(String[] args) { //创建集合对象 Map1.3Map集合的获取功能【应用】map = new HashMap (); //V put(K key,V value):添加元素 map.put("张无忌","赵敏"); map.put("郭靖","黄蓉"); map.put("杨过","小龙女"); //V remove(Object key):根据键删除键值对元素 // System.out.println(map.remove("郭靖")); // System.out.println(map.remove("郭襄")); //void clear():移除所有的键值对元素 // map.clear(); //boolean containsKey(Object key):判断集合是否包含指定的键 // System.out.println(map.containsKey("郭靖")); // System.out.println(map.containsKey("郭襄")); //boolean isEmpty():判断集合是否为空 // System.out.println(map.isEmpty()); //int size():集合的长度,也就是集合中键值对的个数 System.out.println(map.size()); //输出集合对象 System.out.println(map); } }
方法介绍
示例代码
public class MapDemo03 { public static void main(String[] args) { //创建集合对象 Map1.4Map集合的遍历(方式1)【应用】map = new HashMap (); //添加元素 map.put("张无忌", "赵敏"); map.put("郭靖", "黄蓉"); map.put("杨过", "小龙女"); //V get(Object key):根据键获取值 // System.out.println(map.get("张无忌")); // System.out.println(map.get("张三丰")); //Set keySet():获取所有键的集合 // Set keySet = map.keySet(); // for(String key : keySet) { // System.out.println(key); // } //Collection values():获取所有值的集合 Collection values = map.values(); for(String value : values) { System.out.println(value); } } }
遍历思路
我们刚才存储的元素都是成对出现的,所以我们把Map看成是一个夫妻对的集合
把所有的丈夫给集中起来遍历丈夫的集合,获取到每一个丈夫根据丈夫去找对应的妻子
步骤分析
获取所有键的集合。用keySet()方法实现遍历键的集合,获取到每一个键。用增强for实现根据键去找值。用get(Object key)方法实现
代码实现
public class MapDemo01 { public static void main(String[] args) { //创建集合对象 Map1.5Map集合的遍历(方式2)【应用】map = new HashMap (); //添加元素 map.put("张无忌", "赵敏"); map.put("郭靖", "黄蓉"); map.put("杨过", "小龙女"); //获取所有键的集合。用keySet()方法实现 Set keySet = map.keySet(); //遍历键的集合,获取到每一个键。用增强for实现 for (String key : keySet) { //根据键去找值。用get(Object key)方法实现 String value = map.get(key); System.out.println(key + "," + value); } } }
遍历思路
我们刚才存储的元素都是成对出现的,所以我们把Map看成是一个夫妻对的集合
获取所有结婚证的集合遍历结婚证的集合,得到每一个结婚证根据结婚证获取丈夫和妻子
步骤分析
获取所有键值对对象的集合
Set 用增强for实现,得到每一个Map.Entry 根据键值对对象获取键和值
用getKey()得到键用getValue()得到值 代码实现 foreach底层原理 HashMap底层是哈希表结构的依赖hashCode方法和equals方法保证键的唯一如果键要存储的是自定义对象,需要重写hashCode和equals方法
2.2HashMap集合应用案例【应用】
案例需求 创建一个HashMap集合,键是学生对象(Student),值是居住地 (String)。存储多个元素,并遍历。要求保证键的唯一性:如果学生对象的成员变量值相同,我们就认为是同一个对象遍历方式可以选择keySet()、entrySet()、map的默认方法forEach()。 代码实现 学生类 测试类 TreeMap底层是红黑树结构依赖自然排序或者比较器排序,对键进行排序如果键存储的是自定义对象,需要实现Comparable接口或者在创建TreeMap对象时候给出比较器排序规则
3.2TreeMap集合应用案例一【应用】
案例需求 创建一个TreeMap集合,键是学生对象(Student),值是籍贯(String),学生属性姓名和年龄,按照年龄进行排序并遍历要求按照学生的年龄进行排序,如果年龄相同则按照姓名进行排序 代码实现 学生类 测试类 案例需求 给定一个字符串,要求统计字符串中每个字符出现的次数。举例: 给定字符串是“aababcabcdabcde”,在控制台输出: “a(5)b(4)c(3)d(2)e(1)” 代码实现 欢迎分享,转载请注明来源:内存溢出public class MapDemo02 {
public static void main(String[] args) {
//创建集合对象
Map
1.6Map集合的遍历(方式3)【应用】
2.HashMap集合
2.1HashMap集合概述和特点【理解】
public class Student {
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
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 boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Student student = (Student) o;
if (age != student.age) return false;
return name != null ? name.equals(student.name) : student.name == null;
}
@Override
public int hashCode() {
int result = name != null ? name.hashCode() : 0;
result = 31 * result + age;
return result;
}
}
public class HashMapDemo {
public static void main(String[] args) {
//创建HashMap集合对象
HashMap
3.TreeMap集合
3.1TreeMap集合概述和特点【理解】
public class Student implements Comparable
public class Test1 {
public static void main(String[] args) {
// 创建TreeMap集合对象
TreeMap
3.3TreeMap集合应用案例二【应用】
public class Test2 {
public static void main(String[] args) {
// 给定字符串
String s = "aababcabcdabcde";
// 创建TreeMap集合对象,键是Character,值是Integer
TreeMap
评论列表(0条)