黑马程序员—java技术blog—第五篇:Map集合

11 篇文章 0 订阅
11 篇文章 0 订阅

---------------------- <a href="http://edu.csdn.net/heima" target="blank">android培训</a>、<a href="http://edu.csdn.net/heima" target="blank">java培训</a>、期待与您交流! ----------------------

 

一、集合小结

小结:

后缀名就是该集合所属的体系。前缀名就是该集合的数据结构。

看到array 就要想到数组,就要想到查询快,有角标。

看到link 就要想到链表,想到增删快,就要想到add get reomove+first last 方法。

看到hash:就要想到哈希表,就要想到唯一性,就要想到元素需要覆盖hashcode方法和equals方法。

看到tree 就要想到二叉树,就要想到排序,就要想到两个接口comparablecomparator

而且通常这些常用的集合容器是不同步。

 

二、mapCollection的区别

  map:一次添加一对元素。Collection一次添加一个元素。

  map也称为双列集合,Collection集合称为单列集合。

  其实map集合存储的就是键值对。map集合必须保证键的唯一性。

 

三、Map的常用方法

1.添加

 value put(key,value)

//返回前一个和key关联的值;如果没有返回null(如果开始存的key1,v1 如果后面在存的key1,v2,那么v2会替换v1,返回v1,没有就返回null)。

2.删除

void clar()//清空

value remove(key)//根据指定的索引可以删除这个键对。

3.判断

boolean containsKey(Object key); 

boolean containsValue(Object value);

boolean equals(Object o);

 boolean isEmpty();

4.获取

 value get(key)//通过键获取值,如果没有键返回null

 int  size()  // 获取键的个数;

四、常用子类

--Hashtable:内部结构是哈希表,是同步的,不允许null作为键,作为值

   --Properties:用来存储键值对型的配置文件的信息,可以和IO技术相结合。

——HashMap:内部结构是哈希表,不同步的,允许null作为键,作为值。

——TreeMap:内部结构是二叉树,不是同步的。可以对Map集合中的键进行排序。

五、keySet方法和enterSet方法

取出Map中的所有元素。

原理:通过keyset方法获取map中所有的键所在的set集合,在通过set的迭代器获取到每一个键。在对每一个键通过map集合的get方法获取对应的值。

通过entrySet方法:通过map转成set就可以迭代。entrySet方法将键和值的映射关系作为对象存储到了set集合中,而这个映射关系的类型就是Map.Entry<>类型。

例:用ketSet方法取Map元素

import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Set;

public class Demo11 {

public static void main(String[] args) {

// TODO 自动生成的方法存根

Map<Integer, String>map=new HashMap<Integer,String >();

     method(map);

}

public static void method(Map<Integer,String> map){

  map.put(1, "xiaoqiang");

  map.put(2,"zhangshan");

  map.put(3,"lishi");

  map.put(4,"wangwu");

  map.put(5,"sunliu");

  Set<Map.Entry<Integer, String>> p=map.entrySet();

              //定义容器存贮keyset取得的键

  Iterator<Map.Entry<Integer, String>> it=p.iterator();

  while(it.hasNext()){

  Map.Entry<Integer, String> k=it.next();

  Integer key=k.getKey();

                    // 调用Map.Entry<Integer, String>中的方法

  String value=k.getValue();

  System.out.println(key+": "+value);

}      

}     

}          

//输出结果:1: xiaoqiang

            2: zhangshan

            3: lishi

            4: wangwu

            5: sunliu

----- <a href="http://edu.csdn.net/heima" target="blank">android培训</a>、<a href="http://edu.csdn.net/heima" target="blank">java培训</a>、期待与您交流! ----------------------

详细请查看:<a href="http://edu.csdn.net/heima" target="blank">http://edu.csdn.net/heima</a>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值