一、在从数据库取表中的数据时,我们很容易想到使用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 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出现了三次。
读到这儿,要是觉得有用的话,点个赞,打个赞赏吧,你的鼓励是对本人最大的支持。
提个问题,要是分拣思路与面向对象组合解决问题,该怎么做呢,欢迎留言,看的一定回复哦!