Map用法

来源:互联网 发布:python 爬虫金融数据 编辑:程序博客网 时间:2024/04/28 03:49
常用操作说明  void clear()  从此映射中移除所有映射关系(可选操作)。  boolean containsKey(Object key)  如果此映射包含指定键的映射关系,则返回 true。  boolean containsValue(Object value)  如果此映射将一个或多个键映射到指定值,则返回 true。  Set<Map.Entry<K,V>> entrySet()  返回此映射中包含的映射关系的 Set 视图。  boolean equals(Object o)  比较指定的对象与此映射是否相等。  V get(Object key)  返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。  int hashCode()  返回此映射的哈希码值。  boolean isEmpty()  如果此映射未包含键-值映射关系,则返回 true。  Set<K> keySet()  返回此映射中包含的键的 Set 视图。  V put(K key, V value)  将指定的值与此映射中的指定键关联(可选操作)。  void putAll(Map<? extends K,? extends V> m)  从指定映射中将所有映射关系复制到此映射中(可选操作)。  V remove(Object key)  如果存在一个键的映射关系,则将其从此映射中移除(可选操作)。  int size()  返回此映射中的键-值映射关系数。  Collection<V> values()  返回此映射中包含的值的 Collection 视图。

Map的一般用法
1.声明一个Map :
Map map = new HashMap();
2 .向map中放值 ,注意: map是key-value的形式存放的,如:
map.put(“sa”,”dd”);
3 .从map中取值 :
String str = map.get(“sa”).toString,
结果是: str = “dd’
4 .遍历一个map,从中取得key和value :
Map m= new HashMap();
for(Object obj : map.keySet()){
Object value = map.get(obj );
}

/* * To change this template, choose Tools | Templates * and open the template in the editor. */package cn.tsp2c.liubao;import java.util.Collection;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set;import java.util.TreeMap;/** * * @author Administrator */public class TestMap {    public static void main(String[] args) {        Map<String, Student> map = new HashMap<String, Student>();        Student s1 = new Student("宋江", "1001", 38);        Student s2 = new Student("卢俊义", "1002", 35);        Student s3 = new Student("吴用", "1003", 34);        map.put("1001", s1);        map.put("1002", s2);        map.put("1003", s3);        Map<String, Student> subMap = new HashMap<String, Student>();        subMap.put("1008", new Student("tom", "1008", 12));        subMap.put("1009", new Student("jerry", "1009", 10));        map.putAll(subMap);        work(map);        workByKeySet(map);        workByEntry(map);    }//最常规的一种遍历方法,最常规就是最常用的,虽然不复杂,但很重要,这是我们最熟悉的,就不多说了!!    public static void work(Map<String, Student> map) {        Collection<Student> c = map.values();        Iterator it = c.iterator();        for (; it.hasNext();) {            System.out.println(it.next());        }    }//利用keyset进行遍历,它的优点在于可以根据你所想要的key值得到你想要的 values,更具灵活性!!    public static void workByKeySet(Map<String, Student> map) {        Set<String> key = map.keySet();        for (Iterator it = key.iterator(); it.hasNext();) {            String s = (String) it.next();            System.out.println(map.get(s));        }    }  //比较复杂的一种遍历在这里,呵呵~~他很暴力哦,它的灵活性太强了,想得到什么就能得到什么~~    public static void workByEntry(Map<String, Student> map) {        Set<Map.Entry<String, Student>> set = map.entrySet();        for (Iterator<Map.Entry<String, Student>> it = set.iterator(); it.hasNext();) {            Map.Entry<String, Student> entry = (Map.Entry<String, Student>) it.next();            System.out.println(entry.getKey() + "--->" + entry.getValue());        }    }}class Student {    private String name;    private String id;    private int age;    public Student(String name, String id, int age) {        this.name = name;        this.id = id;        this.age = age;    }    @Override    public String toString() {        return "Student{" + "name=" + name + "id=" + id + "age=" + age + '}';    }}//原博客:http://www.jb51.net/article/37874.htm
0 0
原创粉丝点击