Map接口实现类的特点
- Map 与 Collection 并列存在。用于保存具有映射关系的数据:Key-Value
- Map 中的 key 和 value 可以是任何引用类型的数据,会封装到HashMap$Node对象中。
- Map 中的 key 不允许重复,原因和HashSet 一样;若key重复,就会把value的值进行替换。
- Map 中的 value 可以重复。
- Map 中的 key 可以为 null,value 也可以为 null;注意:key 只能有一个为 null,value 可以多个为 null。
- 常用 String 类作为 Map 的 key。注意:不是只用 String类,只要是Object 的子类就行。
- key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到对应的 value。
public class Map_ {
public static void main(String[] args) {
// Map 接口实现类的特点,这里使用实现类HashMap
// Map 与 Collection 并列存在。用于保存具有映射关系的数据:Key-Value
// Map 中的 key 和 value 可以是任何引用类型的数据,会封装到HashMap$Node对象中。
// Map 中的 key 不允许重复,原因和HashSet 一样;若key重复,就会把value的值进行替换。
// Map 中的 value 可以重复。
// Map 中的 key 可以为 null,value 也可以为 null;注意:key 只能有一个为 null,value 可以多个为 null。
// 常用 String 类作为 Map 的 key。注意:不是只用 String类,只要是Object 的子类就行。
// key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到对应的 value。
Map map = new HashMap();
map.put("01","魅族"); //k-v
map.put("02","苹果"); //k-v
map.put("01","华为"); //当有相同的k ,就会对value 进行替换
map.put("03","华为"); //k-v
map.put(null,null); //k-v
map.put(null,"abc");//替换
map.put("04",null); //k-v
map.put("05",null); //k-v
map.put(1,"小米"); //k-v
map.put(new Object(),"三星"); //k-v
// 通过get 方法,传入key ,会返回对应的value 值。
System.out.println(map.get("02")); //苹果
System.out.println(map);
}
}
输出:
苹果
{null=abc, 01=华为, 1=小米, 02=苹果, 03=华为, 04=null, 05=null, java.lang.Object@1b6d3586=三星}
Map接口特点
- k-v 最后是存放在 HashMap$Node node = newNode(hash,key,value,null)
- k-v 为了方便程序员遍历,还会创建 EntrySet 集合,该集合存放的元素的类型 Entry,而一个Entry 对象就有 k,v EntrySet<Entry<K,V>> 即:transient Set<Map.Entry<K,V>> entrySet
- entrySet 中,定义的类型是 Map.Entry,但实际上存放的还是 HashMap$Node,这是因为 static class Node<K,V> implements Map.Entry<K,V>
- 当把 HashMap$Node 对象存放到 entrySet 就会放方便我们遍历,因为 Map.Entry 提供了重要的方法: K getKey(); V getValue();
Map接口常用方法
- put:添加元素
- remove:根据k键 删除元素
- get:根据 k键 获得元素
- size:获取元素个数
- isEmpty:判断个数是否为0
- clear:清楚
- containsKey:查找 键 是否存在
Map map = new HashMap();
map.put("01","魅族"); //k-v
map.put("02","苹果"); //k-v
map.put("01","华为"); //当有相同的k ,就会对value 进行替换
map.put("03","华为"); //k-v
map.put(null,null); //k-v
map.put(null,"abc");//替换
map.put("04",null); //k-v
map.put("05",null); //k-v
map.put(1,"小米"); //k-v
System.out.println(map);
//根据键删除元素
map.remove(1);
System.out.println(map);
//根据键获取元素
System.out.println(map.get("01"));
//获取元素个数
System.out.println("K-V: "+ map.size()+"个");
//判断个数是否为 0
System.out.println(map.isEmpty());
//查找键是否存在
System.out.println(map.containsKey("1"));
输出:
{null=abc, 01=华为, 1=小米, 02=苹果, 03=华为, 04=null, 05=null}
{null=abc, 01=华为, 02=苹果, 03=华为, 04=null, 05=null}
华为
K-V: 6个
false
false进程已结束,退出代码0
704

被折叠的 条评论
为什么被折叠?



