Map集合:该集合存储键值对,一对一对往里存,而且要保证键的唯一性。
1.添加元素
put(K key,V value)
putAll(Map<? extends K,?extends V> m)
2.删除元素
clear()
remove(Object key)
3.判断元素
containsValue(Object value)
containsKey(Object key)
isEmpty()
4.获取元素
get(Object key)
size()
values()
keySet():将map中所有的键存入到Set集合,应为set具备迭代器,所以可以取出所有的键,
在根据get方法,获取每一个键对应的值。
entrySet():将map集合中的映射关系存入到set集合中,而这个关系的数据类型就是map.entry
|--Hashtable: 底层是哈希表数据结构,不可以存入null键null值,线程同步。jdk1.0
|--HashMap:底层是哈希表数据结构,允许使用null键null值,该集合是不同步的。jdk1.2
|--TreeMap:底层是二叉树数据结构,线程不同步,可以用于给map集合中的键进行排序。
import java.util.*;
class MapDemo
{
public static void main(String[] args)
{
Map<String,String> map = new HashMap<String,String>();
//添加元素时,如果键值相同,那么后添加的值会覆盖原有键对应的值。
map.put("01","zhangsan1");
map.put("02","zhangsan2");
map.put("03","zhangsan3");
System.out.println(map.contansKey("022"));
System.out.println(map.remove("02"));
System.out.println(map.get("023"));
//可以通过get方法的返回值来判断一个键是否存在,通过返回null来判断
//获取map集合中所有的值
Collection<String> coll = map.values();
//获取map中的所有键值对。
//先获取map集合的所有键的set集合,keySet();
Set<String> keySet = map.keySet();
Iterator<String> it = keySet.iterator();
while(it.hasNext())
{
String key = it.next();
//有了键可以通过map集合的get方法获取对应的值。
String value = map.get(key);
System.out.println(key,value);
}
////////////////////////////////////////////////////////////////////
//将Map集合中的映射关系取出,存入到set集合。
Set<Map.Entry<String,String>> entrySet = map.entrySet();
Iterator<Map.Entry<String,String>> it = entrySet.iterator();
while(it.hasNext())
{
Map.Entry<String,String> me = it.next();
String key = me.getKey();
String value = me.getValue();
System.out.println(key,value);
}
/*
Map.Entry 其实Entry也是一个接口,它是Map接口中的一个内部接口
interface Map
{
public static interface Entry
{
public abstract Object getKey();
public abstract Object getValue();
}
}
class HashMap implements Map
{
class Hahs implements Map.Entry
{
public Object getKey(){}
public Object getValue(){}
}
}
*/
}
}
---------------------- android培训、 java培训、期待与您交流! ----------------------详细请查看: http://edu.csdn.net/heima