Map基础知识引起的很纠结的问题

来源:互联网 发布:windows正版软件多少钱 编辑:程序博客网 时间:2024/06/13 08:15

首先面临这样一段代码,根据注释代码的意思是根据childr筛选数据

@SuppressWarnings("unchecked")public static List getList(String orgId, String userId,List child) {    if (null == child || child.isEmpty())        return null;    String[] list = getList(orgId, userId);    List order = new ArrayList();    Map temp = new HashMap();    for (int j = 0; j < child.size(); j++) {        EA_SimpleObject so = (EA_SimpleObject) child.get(j);        temp.put(so.getKey(), so);    }    if (null != list && list.length > 0) {        for (int i = 0; i < list.length; i++) {            if (null != temp.get(list[i])) {                order.add(temp.remove(list[i]));            }        }    }    Iterator itOrg = temp.keySet().iterator();    while (itOrg.hasNext())        order.add(temp.get(itOrg.next()));    return order;}

 

 

 

简单解释一下EA_SimpleObject,这个是系统内为方便使用Map而定义的辅助类,只有KeyValue两个属性

首先开始让我郁闷的是order.add(temp.remove(list[i]));根本不明白这是个什么意思,因为我竟然忘了Mapremove后返回什么。直接往下看又看到循环Map存储值,我一下子断定,这个方法对数据根本没有筛选,数据没有多也没有少。而注释上注释着该方法是根据List child进行筛选。

也许大家都在嘲笑,这可不是没有多和少数据吗,更也许大家眨第二眼的时候已经看出来这是个排序了。

将集合数据放到Map中,根据方法内得到的数组数据,如果符合则会执行order.add(temp.remove(list[i]));也就是在Map中删除匹配的数据,然后Mapremove方法返回对应Key的值,这样数据在Map中删除时也存到集合的最前面了。最后遍历Map,将剩下的数据存放到集合中,这样就将传进来的集合,根据方法内获得数组的数据,进行了排序,一些数据优先的放到了集合的前面。

这貌似简单的让人蛋疼,可是对于数月不动代码的我来说,他让我趴下了,无语和狂忍中。

 

请您到ITEYE看我的原创:http://cuisuqiang.iteye.com

或支持我的个人博客,地址:http://www.javacui.com

 

0 0
原创粉丝点击