Map用于保存具有映射关系的数据,因此Map集合里保存着两组值,一组值用于保存Map里的key,另外一组值用于保存Map里的value,key和value都可以是任何引用类型的数据。Map的key不允许重复;key和value之间存在单项一对一关系,即通过指定的key,总能找到唯一的、确定的value。从Map中取出数据时,只要给出指定的key,就可以取出对应的value
一、HashMap
1.1、Map.Entry
Map中包括了一个内部类Entry,该类封装了一个key-value记录
1.2、常用方法
二、HashTable
Hashtable和HashMap使用方法基本一致
HashMap和HashTable的区别
Hashtable不允许使用null作为key和value,如果试图把nul放进HashTable中,将会引发NullPointerException异常;但HashMap可以使用null作为key或value
Hashtable是一个线程安全的Map实现类,但HashMap是线程不安全的实现类,所以HashMap要比Hashtable的性能高一点;但是如果有多个线程访问同一个Map对象时,使用Hashtable实现类会更好
代码实例:
public class Jtest {
@Test // 快捷键ctrl +1
public void test1() {
// Map集合容器
// 1、Map集合中保存的记录都是成对出现的,key-value(键值对/名值对),每一个key对应一个value
// 2、Map中保存的记录是唯一的,相同key的记录后添加的会替换原有的
// 3、在Map集合容器中,所有的记录(key-value)都保存在Entry对象中
/**
* HashMap保存数据是惟一的,无序的
* LinkedHashMap保存数据是惟一的,有序的
* HashMap在多线程开发环境下是不安全的
* HashTable在多线程开发环境下是安全的(原因是具备线程的同步锁)
*/
}
@Test
public void test2() {// Map集合容器基本案例
// 第1步:创建一个HashMap集合容器,用于保存键值对(key-value)
Map<String, String> cities = new HashMap<String, String>();
// 第2步:向HashMap集合容器中添加记录(key-value)(省名称-省会城市名称)
cities.put("吉林省", "长春市");
cities.put("浙江省", "杭州市");
cities.put("辽宁省", "沈阳市");
cities.put("黑龙江省", "哈尔滨市");
// 第3步:通过省的名称(key)找到对应的省会城市名称(value)
System.out.println(cities.get("浙江省"));
// 删除key为浙江省的记录
cities.remove("浙江省");
// 删除所有记录的方法(清空)
cities.clear();
// 第4步:遍历HashMap集合容器
Set<Entry<String, String>> ens = cities.entrySet();// 通过entrySet方法获得Entry对象集合
for (Entry<String, String> en : ens) {
String k = en.getKey();// 获得该条记录中的key
String v = en.getValue();// 获得该条记录中的value
System.out.println("名:" + k + ",值:" + v);
}
}