黑马程序员技术交流社区

标题: 集合——MAP [打印本页]

作者: ︶ㄣ你眼中的倒    时间: 2014-9-24 16:59
标题: 集合——MAP
概述:

基本特点:

     该集合存储键值对,而且要保证键的惟一性

子类:

    |--HashTable 底层是哈希数据表结构,不可以使用Null作为键或者值;该集合线程是同步的

    |--hashMap   底层是哈希数据表结构,可以使用Null作为键或者值,该集合线程是不同步的

    |--treemap   底层是二叉树结构,线程不同步,可以对Map中的键值可以排序

   Map集合的两种取出方式(原理:将map集合转换成set,再使用迭代器)

   1、keySet:将map中所有的键存入到set集合,因为set具备迭代器。所有可以迭代方式取出所有的键,在根据get方法.获取每一个健对应的值。

   2、entrySet   set<MAP.Entry<>>

示例代码如下:

class Demo{
public static void main(String args[]){
  Map<String ,String> map=new HashMap<String,String>();
  //添加元素
  map.put("01","lisi0");
  map.put("02","lisi1");
  map.put("03","lisi2");
  map.put("04","lisi3");
  //先获取map集合的所有键的set集合,keyset();
  Set<String> keySet=map.keySet();
  //有了set集合,就可以获取迭代器
  Iterator<String> it = keySet.iterator();
  while(it.hasNext()){
   String key=it.next();
   String value=map.get(key);
   System.out.println("key::"+key+" value::"+value);
   //
  }
  //将map集合中的映射关系取出。存入到set集合
  Set<Map.Entry<String,String>> entrySet =map.entrySet();
  Iterator<Map.Entry<String,String>> rt = entrySet.iterator();
  while(rt.hasNext()){
   System.out.println("rt::"+rt.next());
   Map.Entry<String,String> me=rt.next();
   String key=me.getKey();
   String value=me.getValue();
   System.out.println("key::"+key+"::value::"+value);
  }
}





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2