Java Map
是一种key-value的映射关系的集合
key不允许重复,value可以重复,举例可以看成学号与姓名的关系。
HashMap中key可以设为null,在TreeMap中key不可以为null
原因:TreeMap在存入数据后会进行排序,所以key不可以为空
key与value的值是可以随意设置的
在项目中如果存在类似于学号和姓名这样有对应关系的数据存储,一般会选择使用Map.
代码
package test;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class Test {
public void test() {
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Map<Integer,String> map = new HashMap<>();
Map<Integer,String> map1 = new HashMap<>();
map.put(1, "小高");//在map中存入key与value的属性
map.put(2, "小红");
map.put(3, "小刘");
map.put(4, "小王");
String str = map .get(2);
map1.putAll(map);//可以将新的map全部赋值与原有的map相同
String str2 = map1.get(3);
System.out.println(str);
System.out.println(str2);
Collection<String> list = map.values();//values的属性用于获得map中的value
Iterator<String> it1 = list.iterator();
while(it1.hasNext()) {
System.out.println(it1.next());
}
Set<Integer> se = map.keySet();//keySet属性用于获取map中的key
Iterator<Integer> it2 = se.iterator();//Iterator(迭代器)用于访问集合,遍历整个集合中的所有元素
/*迭代器有三种使用方式
* it.next()用于返回迭代器的下一个元素,并且更新迭代器的状态;
* it.hasNext()用于检测集合中是否还有元素的存在
* it.remove()用于将迭代器返回的元素删除
*/
while(it2.hasNext()) {
System.out.println(it2.next());
}
Set<Map.Entry<Integer, String>> set = map.entrySet();
/*
* entrySet方法可以对整个表进行一次遍历,最终出现的结果以表的方式呈现
* 实现了单线程条件下key与value的同时遍历
*/
Iterator<Map.Entry<Integer, String>> it3 = set.iterator();
while(it3.hasNext()) {
Map.Entry<Integer, String> en = it3.next();
System.out.println(en.getKey()+"\t"+en.getValue());
}
}
}