在学数据结构的时候就学到过 Hash 存储,在 java 中使用数组时也听过 HashMap 这种数据结构,但是对于 HashMap 怎样用就不会了。以前感觉 HashMap 应该好难用,有数组就够了,干嘛非得用这个结构。。。在这次实习后,我大大改变了自己的看法,在某些需求下, HashMap 太好用了!!
HashMap 是基于哈希表的 Map 接口的实现,它是一个散列表,它存储的内容是键值对(key-value)映射,就跟 json 格式一样,通过 key 获取 value 的值。
这篇文章也就只是用来记忆一下如何使用 HashMap ,并不会对其展开叙述,对于想快速上手的可以看看。
首先创建 HashMap 对象,使用以下一行代码进行创建,在里面我想说的是 HashMap<String,Integer> 中的 String 和 Integer 是可以根据自己的需求来改变的,并且不能使用原始类型(即 int 、double)关于这一点可以看我这篇文章https://blog.csdn.net/qq_39187675/article/details/101764511里面有相关叙述。
HashMap<String,Integer> hashmap=new HashMap<>();
下面用一个小 demo 来演示如何使用 hashmap 。重点是看代码注释。唯一需要注意的是 HashMap 中的 key 不能重复,否则后面的数据会覆盖掉前面所添加的数据,还有就是它是无序的,输出时顺序不一定。
import java.util.HashMap;
import java.util.Map;
public class demo {
public static void main(String[] args) {
//创建一个 HashMap 对象
HashMap<String,Integer> hashmap=new HashMap<>();
//往hashmap中插入数据使用put()方法
hashmap.put("数学", 78);
hashmap.put("英语", 88);
hashmap.put("语文", 86);
//遍历hashmap,这个估计是大多数人都不会的
for (Map.Entry<String,Integer> item : hashmap.entrySet()) {
System.out.println(item.getKey()+" "+item.getValue());
}
/* 以下上面遍历的是输出
数学 78
语文 86
英语 88
*/
// 通过上面的遍历我们可以知道hashmap中以及存在了上述数据
// 下面在来插入一个数据看看会有什么不同
hashmap.put("语文", 100);
for (Map.Entry<String,Integer> item : hashmap.entrySet()) {
System.out.println(item.getKey()+" "+item.getValue());
}
/* 通过下面我们可以看到语文的成绩变成了100,原来的86没有了,这就说明在 HashMap 中,key 的值不能重复,如果存在重复值,则后面的值会把前面的值给覆盖掉
数学 78
语文 100
英语 88
*/
// 我们可以用 containskey()方法来判断里面是否存在某个key
if(hashmap.containsKey("数学"))
System.out.println("存在key=数学");
else
System.out.println("不存在该key=数学");
}
}