Map的神奇用法,你了解多少呢?

简介: Map的神奇用法,你了解多少呢?

一、在从数据库取表中的数据时,我们很容易想到使用List集合。其实我们也可以使用Map集合,首先根据表新建实体类,并实现set,get方法。

public class Employee {
  private int id;
  private String name;
  private int salary;
  private String department;
  private Date hireDate;

当我们保存时,这样保存:

Map map = new HashMap<>();
    map.put("id", "1111");
    map.put("name","小明");
    map.put("salary",1100 );
    map.put("department", "2103");
    map.put("hireDate","2019-01-12");

然后我们把每个map保存到List集合中。

  List<Map> list = new ArrayList<Map>();
    list.add(map);
    list.add(map2);
    list.add(map3);

那么如何遍历呢?我们写一个方法》,调用即可。

public static void printEmpName(List<Map> list) {
    for(int i=0;i<list.size();i++) {
      Map tempMap=list.get(i);
      System.out.println(tempMap.get("id")+":"+tempMap.get("name")
      +":"+tempMap.get("salary")+":"+tempMap.get("department")+
      ":"+tempMap.get("hireDate"));
    }

下面我们介绍一下迭代器遍历Map集合的另一种方法,因为在实际开发中,主要用迭代器遍历。没有索引,只能用增强foreach或者迭代器。对于list集合,我们可以用for循环,set无序,只能用迭代器Iterator.set的示例如下:

Set set=new HashSet<>();
    set.add("aaaa");
    set.add("bbbb");
    set.add("cccc");
//while遍历
Iterator iterator=set.iterator();
//迭代器hasnext()判断是否有下一个,有返回true,没有返回 false
while(iterator.hasNext()) {
   String string=(String) iterator.next();
   //next()返回当前位置的游标对应的元素,并指向下一个。
   System.out.println(string);
}
//for遍历
for(Iterator iterator=set.iterator();iterator.hasNext();) {
      String string=(String) iterator.next();
      System.out.println(string);
    }

那对于上面的list,也是一样的,都是用了Iterator迭代器。

Iterator lter=list.iterator();
    while(lter.hasNext()) {
      Map tempMap=(Map) lter.next();
      System.out.println(tempMap.get("id")+":"+tempMap.get("name")
      +":"+tempMap.get("salary")+":"+tempMap.get("department")+
      ":"+tempMap.get("hireDate"));
    }

二、讲了这么多的遍历,下面我们来说一下Map的经典存储,分拣思路。通过一个例子,我们逐步说说,你会感受到map的强大的。


//统计每个单词出现次数

// I love you and you love me this is very perfect do you know?

这个题目我们来用map实现,先来拿到这个句子,用split分割。

String str = "I love you and you love me this is very perfect do you know?";
    // 分割字符串
    String[] strArray = str.split(" ");
    // 存储到Map中
    Map<String, Letter> letters = new HashMap<String, Letter>();

然后我们在Map中,前面的string是存放单词的,后面的Letter可以记录该单词的name和出现的count。,该实现类代码如下:

public class Letter {
  private String name;
  private int count;
  public Letter(String name, int count) {
    super();
    this.name = name;
    this.count = count;
  }
  public Letter() {
    super();
    // TODO Auto-generated constructor stub
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public int getCount() {
    return count;
  }
  public void setCount(int count) {
    this.count = count;
  }
}

根据物流理解:分拣思路 比如来一个包裹,北京的放一个容器,上海的分一个容器,没有的再来一个容器,有的就不用创建容器了,往对应的容器加。在该问题中,我们有两种思路

1、为所有的key创建容器,之后容器中存放对应的value

for (String temp : strArray) {
      if (!letters.containsKey(temp)) {// 判断Map集合中有没有temp这个键。
        letters.put(temp, new Letter());// 没有的就创建容器
      }
      Letter col = letters.get(temp);// Map的get方法是为了通过key得到value
      // 而该value是Letter对象。
      col.setCount(col.getCount() + 1);//让数量加1.
    }

2、第一次创建容器并存放值,第二次直接使用容器存放值。

// 2、第一次创建容器并存放值
      for (String temp : strArray) {
          Letter col=null;
          if (!letters.containsKey(temp)) {// 判断Map集合中有没有temp这个键。
            col=new Letter();
            col.setCount(1);//第一次值容器就存放容器中。
            letters.put(temp, col);// 没有的就创建容器
          }
          //第二次直接使用容器存放值。
          else {
            col = letters.get(temp);// Map的get方法是为了通过key得到value
            // 而该value是Letter对象。
            col.setCount(col.getCount() + 1);
          }
        }

对第二种演变一下。不使用containsKey了

// 2、第一次创建容器并存放值
    for (String temp : strArray) {
      Letter col=null;
      if (null==(col=letters.get(temp))) {// 判断Map集合中有没有temp这个键。
        col=new Letter();
        col.setCount(1);//第一次值容器就存放容器中。
        letters.put(temp, col);// 没有的就创建容器
      }
      //第二次直接使用容器存放值。
      else {
        // 而该value是Letter对象。这次在if判断中已经get()过了
        col.setCount(col.getCount() + 1);
      }
    }

分拣思路对于HashMap存值是非常重要的思路。

现在我们试一下用keyset()来打印输出我们上面保存的map集合。

//输出Map的值
    //返回此映射中包含的键的set视图。就是键的所有弄成set集合
    Set<String> keys=letters.keySet();
    for (String key : keys) {
       Letter col =letters.get(key);
      System.out.println("字母:"+key+".次数:"+col.getCount());
    }

结果如下,可以看出这是一段表白的话,为什么呢,没几个词love都出现了两次,you出现了三次。

image.png

读到这儿,要是觉得有用的话,点个赞,打个赞赏吧,你的鼓励是对本人最大的支持。

提个问题,要是分拣思路与面向对象组合解决问题,该怎么做呢,欢迎留言,看的一定回复哦!

目录
相关文章
|
8天前
|
安全 C#
C# List基本用法
C# List基本用法
|
9月前
|
存储 程序员 C++
C++中map的使用方法
map是一种使用键值对的数据结构,它允许我们使用键来查找值。map中的键必须是唯一且有序的,而值可以重复并且没有特定的顺序。 map中的数据以树结构进行组织,其中每个节点都由一个键和一个值组成。根据键的大小,节点被插入到正确的位置以保持树的有序性。这使得在map中查找值非常高效,因为我们可以使用二分查找来快速定位值。
194 0
|
2月前
|
C++
stl中set、map的用法
stl中set、map的用法
|
4月前
|
存储 自然语言处理 C++
C++ STL中 set和map介绍以及使用方法
C++ STL中 set和map介绍以及使用方法
59 1
|
10月前
|
算法 C++ Python
C++中map的用法
⭐一、map的简介 map是C++STL中的一个关联式容器,它提供一对一的hash,它类似于Python中的字典,也有着键值对(Key-Value)这一说。我们可以通过键(Key)来找到值(Value),但需要注意的是,每个键(Key)只能在map中出现一次哦! map可以储存多种类型的数据,它主要用于一对一映射的情况,map内部的实现是通过自建一颗红黑树,这颗树可以对数据进行自动排序。所以在map内部所有的数据都是有序的,这个功能以后可以方便我们解决很多问题。
266 0
|
索引
forEach用法与map用法区别
forEach用法与map用法区别
147 0
Java中Map的 entrySet() 详解以及用法(四种遍历map的方式)
Java中Map的 entrySet() 详解以及用法(四种遍历map的方式)
|
容器 C++ 数据处理
map函数
最近开发中使用到map函数,就做了一些小整理;map:STL的一个类容器,提供一对一的数据处理(键值对),平常我们都用于处理一对一数据时,在编程上提供快速通道。map内部自建一颗红黑树。 概念:STL容器:Standard Template Library的简称,中文名标准模板库,惠普实验室开发的一系列软件的统称。
1061 0