Map 类型

public Map getArea() {
DbConn db;
String sql = "Select * from area";
ResultSet rs = null;
Map reply = new LinkedHashMap();
try {
db = new DbConn();
rs = db.quary(sql);
while (rs.next()) {
reply.put(rs.getString("area_id"), rs.getString("area_name"));
db.closed();
}
} catch (Exception e) {
e.printStackTrace();
}
return reply;

}

能不能解释下map类型是干什么用的

reply.put(rs.getString("area_id"), rs.getString("area_name"));
put方法呢?
谢谢,能理解一点

如果area表里的area_id 和 area_name 有多个的话
那reply里也有多个映射?

我的意思是多组id,name
reply的map里是不是也有多组映射?

  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()  
  entrySet()  
  keySet()
  
  Map
  |--Hashtable:底层是哈希表数据结构,不可以存入null
  键null值。该集合是线程同步的。jdk1.0.效率低。
  |--HashMap:底层是哈希表数据结构,允许使用 null 值
  和 null 键,该集合是不同步的。将hashtable替代,jdk1.2.效率高。
  |--TreeMap:底层是二叉树数据结构。线程不同步。可
  以用于给map集合中的键进行排序。和Set很像。其实大家,Set底层就是使用了Map集合。 map集合的两种取出方式:
  1,Set<k>keySet:将map中所有的键存入到Set集合。因为set具备迭代器。
  所有可以迭代方式取出所有的键,在根据get方法。获取
  每一个键对应的值。
  Map集合的取出原理:将map集合转成set集合。在通
  过迭代器取出。 importjava.util.*;
  

  class MapDemo2 {
  public static void main(String[] args)
  {
  Map<String,String> map = new
  HashMap<String,String>();
  map.put("02","zhangsan2"); map.put("03","zhangsan3"); map.put("01","zhangsan1");
  map.put("04","zhangsan4");
  /* //先获取map集合的所有键的Set集合,keySet();  
  Set<String>keySet = map.keySet(); //有了Set集合。就可以获取其迭代器。  
  Iterator<String> it = keySet.iterator();
  while(it.hasNext()) { 
  String key = it.next();
  //有了键可以通过map集合的get方法获取其对应的值。 String value =map.get(key);
  System.out.println("key:"+key+",value:"+value);
  }  
  2,Set<Map.Entry<k,v>>entrySet:将map集合中的映射关系存入到了set集合中,而这个关系的数据类型就是:Map.Entry.
  Entry其实就是Map中的一个static内部接口。
  为什么要定义在内部呢?
  因为只有有了Map集合,有了键值对,才会有键值的映射关系。
  关系属于Map集合中的一个内部事物。
  而且该事物在直接访问Map集合中的元素。
  //将Map集合中的映射关系取出。存入到Set集合中。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2008-10-13
呵呵,就因为只有id和name,所以才最适合用Map,
如果有多个,一般是构造一个 Area的类,然后用
map.put(id,area) 把一个Area类放进去!
================================
map.put第一个参数是key,如果2次操作key相同,则前面的被覆盖了。

所以,如果你有多个id/name 你可以put多次,因为他们的id不同,也就是key不同,所以正好满足了你的要求。

你使用时,如果找 id=123的name,简单的

map.get(123) 就可以了。 是不是很好用。本回答被提问者采纳
第2个回答  2008-10-13
map是用来存放一组一一映射关系的,在map中,一个x只能对应一个y
map.put(x,y);是把一个映射存入map