容器的另一个顶级接口Map
Map<Key,Value>中存放的时K-V对。防止内容的时候,确定一个Key值和V值,这两个值一一对应,当我们取值的时候,使用的是Key值来取出V值
Map在此意为:映射表
1)HashMap<> ()
HashMap中的一些方法
Map<String,String> map = new HashMap<>();
map.put("wang","wangyanwei"); //添加内容的方法
map.put(Key)-->map.put("wang"); // 必须用Key值取V值
map.put("wang","wangyan"); //会替换Key值相同的K-V对
list<Student> list = new ArrayList<>();
list.addAll(map.values()); //将所有的V值放在一个集合中,之后就可以用角标
map.entrySet() 返回的值就是这个map中各个键值对映射关系的集合。
可使它对map进行遍历:
(1)第一种实现方法
Iterator<Map.Entry<Integer,Integer>> it = map.entrySet().iterator();
while(it.hasNext()) {
Map.Entry<Integer,Integer> entry = it.next();
int key = entry.getKey();
int value = entry.getValue();
System.out.println(key +" "+ value);
}
(2)第二种实现方法
Set<Map.Entry<String,Student>> entris = map.entrySet();
for(Map.Entry<String,Student> item : entries) {
System.out.println(item.getKey() +":"+ item.getValue());
}
2)HashMap的遍历方式
(1)纵切遍历方式
先将Key队列当作Set拿出,遍历Set时也同时将V值拿出。
Set<String> keys = map.keySet(); //将所有的key值取出,放置在Set容器中,此时的Set为HashSet。
for(String item : keys) {
System.out.println(item +" "+ map.get(item).name);
}
System.out.println();
(2)横切遍历方式
每一次拿出的都是一个K-V对,还是用的Set集合。Map中存放内容时一行一行进行存放的,这么一行在Map中成为 Map.Entry
3)HashMap的存储方式
4)HashTable<T,E> ()
HashTable<String,String> table = new HashTable<>();
table.put("String","String");
HashTable与HashMap的区别时:HashMap可以放置空值,HashTable中K值以及V值其中任意一个都不能为空。(底层因为HashTable由线程锁,是线程安全的。HashMap是线程不安全的)