由上图我们可以看到在Map集合中,HashMap和LinkedHashMap直接实现了Map接口。接下来总结HashMap常用方法:
1.put(K key, V value) 将键(key)/值(value)映射存放到Map集合中,向HashMap中添加元素
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
int score=map.get("Tom");
System.out.println(score);
map.put("Tom", 90);
score=map.get("Tom");
System.out.println(score);
}
}
2.get(Object key) 返回指定键所映射的值,没有该key对应的值则返回 null
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.get("Lucy"));
System.out.println(map.get("Tom"));
}
}
3.size() 返回Map集合中数据数量
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.size());
}
}
此时的运行结果为2
4.clear() 清空Map集合
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.size());
map.clear();
System.out.println(map.size());
}
}
5.isEmpty () 判断Map集合中是否有数据,如果没有则返回true,否则返回false
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.size());
map.clear();
System.out.println(map.size());
System.out.println(map.isEmpty());
}
}
6.remove(Object key) 删除Map集合中键为key的数据并返回其所对应value值。
package map;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.remove("Tom"));
}
}
此时代码的运行结果为100
7.values() 返回Map集合中所有value组成的以Collection数据类型格式数据。
package map;
import java.util.Collection;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.remove("Tom"));
Collection con = map.values();
for (int score : con) {
System.out.println(score);
}
}
}
8.containsKey(Object key) 判断集合中是否包含指定键,包含返回 true,否则返回false
package map;
import java.util.Collection;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.containsKey("Lucy"));
}
}
此时的返回值为false
9.containsValue(Object value) 判断集合中是否包含指定值,包含返回 true,否则返回false
package map;
import java.util.Collection;
import java.util.HashMap;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
System.out.println(map.containsValue(90));
}
}
此时的返回值为true
10.keySet() 返回Map集合中所有key组成的Set集合
package map;
import java.util.Collection;
import java.util.HashMap;
import java.util.Set;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
Set set=map.keySet();
for (String key: set) {
System.out.println(key+" "+map.get(key));
}
}
}
11.entrySet() 将Map集合每个key-value转换为一个Entry对象并返回由所有的Entry对象组成的Set集合
我们先来看下面一段代码:
package map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
Set set=map.keySet();
for (String key: set) {
System.out.println(key+" "+map.get(key));
}
Iterator iterator=set.iterator();
while(iterator.hasNext()) {
String key=iterator.next();
System.out.println(key+" "+map.get(key));
}
}
}
此时如果转化成Entry的形式的话,则为下面的形式:
package map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
public class Test {
public static void main(String[] args) {
HashMap map=new HashMap();
map.put("Tom",100);
map.put("Jim", 90);
Set> set=map.entrySet();
for (Entry entry : set) {
System.out.println(entry.getKey()+" "+entry.getValue());
}
Iterator> iterator=set.iterator();
while(iterator.hasNext()) {
Entry entry=iterator.next();
System.out.println(entry.getKey()+" "+entry.getValue());
}
}
}