Java基础-Map
创始人
2024-06-03 10:34:20
0

1.Map的常见API

方法名称说明
V put(K key , V  value)添加元素(如果键存在,覆盖value,并返回原有的value)
V remove (Object key)根据键删除键值对元素
void clear()移除所有的键值对元素
int size ()集合的长度
boolean  isEmpty()  判断集合是否为空
boolean containKey(Object key)判断集合是否包含指定的键

  1. 由于Map是一个接口,所以在Map对象的时候,不能直接创建Map对象,要创建Map的实现类对象
    Map map = new HashMap();

2.Map的遍历方式

    2.1 通过键找值

 

package cn.sxau.集合.Map;import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.function.Consumer;public class Map集合遍历方式一 {public static void main(String[] args) {Map map = new HashMap<>();map.put("name","张安");map.put("age","18");map.put("address","北京市");map.put("gender","男");/***  通过键找值*  1.将键存放到一个单列集合*  2.遍历单列集合得到key*/Set keys = map.keySet();
//        for (String key: keys
//             ) {
//            String value = map.get(key);
//            System.out.println(key + "=" + value);
//        }keys.forEach((String s) ->System.out.println(s+"=" +map.get(s)));}
}

    2.2 通过键值对

 核心思想:通过一个方法获取所有的键值对对象,返回一个set集合,再遍历该集合

package cn.sxau.集合.Map;import java.util.HashMap;
import java.util.Map;
import java.util.Set;public class Map集合遍历方式二 {public static void main(String[] args) {Map map = new HashMap<>();map.put("name","张安");map.put("age","18");map.put("address","北京市");map.put("gender","男");/***  通过键值对**/Set> entries = map.entrySet();for (Map.Entry entrie:entries) {String key = entrie.getKey();String value = entrie.getValue();System.out.println(key+ "=" + value);//System.out.println(entrie);}}
}

    2.3 Lambda

方法:default void forEach(BiConsumer action) 

package cn.sxau.集合.Map;import java.util.HashMap;
import java.util.Map;
import java.util.function.BiConsumer;public class Map集合遍历方式三 {public static void main(String[] args) {Map map = new HashMap<>();map.put("name","张安");map.put("age","18");map.put("address","北京市");map.put("gender","男");map.forEach(new BiConsumer() {@Overridepublic void accept(String key, String value) {System.out.println(key + "="+ value);}});System.out.println("======================");map.forEach(( key,value) ->System.out.println(key + "="+ value));}}

3.HashMap 

 HashMap是Map的实现类

 特点:无序,不重复,无索引

  1. 案例
     创建一个HashMap集合,键是学生对象(Studnet),值是籍贯要求:相同姓名,相同id,就是同一个对象
    package cn.sxau.集合.Map.HashMap;import java.util.Objects;public class Studnet {private int id;private String name;public Studnet() {}public Studnet(int id, String name) {this.id = id;this.name = name;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic boolean equals(Object o) {if (this == o) {return true;}if (o == null || getClass() != o.getClass()) {return false;}Studnet studnet = (Studnet) o;return id == studnet.id && Objects.equals(name, studnet.name);}@Overridepublic int hashCode() {return Objects.hash(id, name);}@Overridepublic String toString() {return "Studnet{" +"id=" + id +", name='" + name + '\'' +'}';}
    }
    package cn.sxau.集合.Map.HashMap;import java.util.HashMap;
    import java.util.Set;public class HashMapDemo1 {public static void main(String[] args) {/*** 创建一个HashMap集合,键是学生对象(Studnet),值是籍贯* 要求:相同姓名就是同一个对象*/HashMap hashMap = new HashMap<>();Studnet s1 = new Studnet(1,"占山");Studnet s2 = new Studnet(2,"张三");Studnet s3 = new Studnet(3,"李四");Studnet s4 = new Studnet(3,"李四");hashMap.put(s1,"北京");hashMap.put(s2,"山西");hashMap.put(s3,"山东");hashMap.put(s4,"南极");//遍历:将键值对存储在单列集合,Set keys = hashMap.keySet();keys.forEach((s) ->System.out.println(s + "=" +hashMap.get(s)));}
    }
    

    2.案例二:890个学生投票给A,B,C,D4个景点,求出投票最多得景点得名字和票数

    package cn.sxau.集合.Map.HashMap;import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.Random;
    import java.util.Set;public class HashMapDemo2 {public static void main(String[] args) {/*** 景点ABCD ,统计80个学生的票数*///1.投票String[] arr = {"A", "B", "C", "D"};ArrayList arrayList = new ArrayList<>();Random random = new Random();for (int j = 0; j < 80; j++) {int index = random.nextInt(arr.length); //生成的下标是 [0-4)arrayList.add(arr[index]);}//2.统计HashMap hashMap = new HashMap<>();for (String name : arrayList) {if (hashMap.containsKey(name)) {/*** 如果存在* 1.先获取当前景点已经被投票的次数* 2.自增*/int count = hashMap.get(name);count++;hashMap.put(name,count);} else {hashMap.put(name, 1);}}System.out.println(hashMap);/***   求票数最大值*   1.遍历hashMap集合(通过遍历key,得到value),得到最大得value*   通过value得到key*/int max = 0;Set keySets = hashMap.keySet(); //将key存放在单列集合中for (String key: keySets) {Integer integer = hashMap.get(key);if(integer>max){max = integer;}}System.out.println(max);for (String key: keySets) {Integer integer = hashMap.get(key);if(integer == max){System.out.println(key);}}}
    }
    

     

 4.LinkedHashMap

特点:由键决定,有序(保证存储和取出得元素顺序是一致的,通过双链表机制记录存储顺序),不重复,无索引

public class LinkedHashMapextends HashMap  //继承HashMapimplements Map   //实现Map接口
{

5. TreeMap

    特点:由键决定的,不重复,无索引,可排序(对键进行排序)

   5.1 排序规则:

  1. 实现Compareble接口,指定比较规则
  2. 创建集合时传递Comparator比较器对象,指定比较规则
  3. 案例实现
    package cn.sxau.集合.Map;import java.util.Comparator;
    import java.util.TreeMap;public class TreeMap的排序 {/*** 案例一:键值对是(id,商品名称),按照id的升序排序(默认),或者按照降序排序* @param args*/public static void main(String[] args) {TreeMap treeMap = new TreeMap<>(new Comparator() {@Overridepublic int compare(Integer o1, Integer o2) {//o1:表示当前要添加的元素//o2:表示已经在红黑树中存在的元素return o2-o1;}});treeMap.put(3,"鲜虾鱼板面");treeMap.put(1,"老坛酸菜面");treeMap.put(2,"驴胶补血颗粒");System.out.println(treeMap);}}
    

相关内容

热门资讯

请问怎么乘坐地铁,方法,步骤? 请问怎么乘坐地铁,方法,步骤?首先我没见过,更没有坐过,所以我要问怎么坐地铁啊???其次广州不坐地铁...
两小时内告诉我答案!!! 我的... 两小时内告诉我答案!!! 我的喜欢 运动 看电影 读书 用韩语怎么翻译??저의 취미는 운동, 영화...
有没有主角实力强大却隐藏起来只... 有没有主角实力强大却隐藏起来只想平凡的过完生活的小说巜我真的长生不老》主角高中生,喜欢古典文化和同班...
郭德纲的长篇单口相声《今古奇观... 郭德纲的长篇单口相声《今古奇观》系列什么时候能完?听说是跟一个外地的出版社合作出版的,又没有消息灵通...
秋天的特点是什么? 秋天的特点是什么?秋季有三大特点:干燥、寒冷、果实成熟季。首先来说,干燥的天气,是秋天的必经过程,夏...
如何改写一个伤感的故事? 如何改写一个伤感的故事?一般故事的结局是最能体现伤感的。所以修改这个故事的结局。就能改掉这个伤感的故...
自然哲学是指什么 自然哲学是指什么自然哲学是指什么自然科学的前身 用哲学方法探求世界基本规律哲学的英文单词是philo...
考生报考教师招聘各年级段所需要... 考生报考教师招聘各年级段所需要的学历要求分别是什么?如果是报考幼师资格证需具有幼儿师范学校毕业或高等...
我表妹马上过20岁生日了,我想... 我表妹马上过20岁生日了,我想送首藏头诗或者藏尾诗给她,她的名字叫:沈明玉沈府佳人美无比,明月高照玉...
形容人讨厌成语 形容人讨厌成语 面目可憎miàn mù kě zēng[释义] 面目:面貌;可憎:令人厌恶。相貌...
为什么一听到声音就特别烦躁,有... 为什么一听到声音就特别烦躁,有时候还会控制不住想哭?是不是你最近压力太大了?去看看心理医生吧。要不然...
有没有知道名家描写四季的文章? 有没有知道名家描写四季的文章?只要是家描写四季的文章都行,大家帮找找吧~最好是夏天和冬天的~大家帮帮...
学习计划书的格式 学习计划书的格式急急急急急啊学习计划书格式分三块:1.学习计划书名称仔细回顾一下自己的学习情况,找出...
四年级下册暑假生活指导参考答案... 四年级下册暑假生活指导参考答案山东教育出版社(英语)是2011年的 是帮助tony闯关的。急急...
《翼年代记之东京默示录》主要讲... 《翼年代记之东京默示录》主要讲什么的讲的就是故事讲小樱及小狼来自玖楼国(在日文中,《魔卡少女樱》的大...
纪晓岚简介 纪晓岚简介 纪昀(jǐ yún),字晓岚,一字春帆,晚号石云,道号观弈道人。生于清雍正二年(17...
昨天买的奶茶今天有了一点沉淀物... 昨天买的奶茶今天有了一点沉淀物,还有一点酸味,还吃得了吗?如果你买的不是酸奶最好是不要吃了!这么热的...
冲熬是什么意思 冲熬是什么意思冲熬是什么意思封建迷信的意思
实木家具油漆工艺流程 实木家具油漆工艺流程实木家具刷油漆的方法步骤:第一步,卸把手等装饰品,为了防止把手等饰品沾上油漆,刷...
我想买一台收音机给我奶奶,请问... 我想买一台收音机给我奶奶,请问大家什么电台最适合老人听?最好是没有医学专家讲座的电台。谢谢各位了! ...