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

本文介绍了一种使用Java Map和List实现的特殊排序方法。通过将数据放入Map,并根据指定顺序取出部分数据,再取出剩余数据的方式,实现了对原始List的重新排序。此方法巧妙利用了Map的特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先面临这样一段代码,根据注释代码的意思是根据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而定义的辅助类,只有Key,Value两个属性

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

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

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

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

 

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值