Java的Map.Entry的方式实现Map树

该博客主要展示了如何通过Map.Entry处理JSON字符串,构建一个以部门ID为键,包含父ID、部门名称等信息的树形结构数据。在处理过程中,首先将JSON转换为Map列表,然后递归地获取所有子节点,并更新每个节点的路径信息。

构造Map的方式树形结构,使用Map.Entry的方式实现

	private void testDept(){
        String jsonStr="[{\"id\":1,\"name\":\"晨晨\",\"order\":100000000," +
                "\"parentId\":0},{\"id\":2,\"name\":\"小晨晨\",\"order\":100000000,\"parentId\":1},{\"id\":3,\"name\":\"大晨晨\",\"order\":99999000,\"parentId\":1}]";
        Map three = getThree(jsonStr,1);
        System.out.println(three);
    }
    private static Map getThree(String jsonStr,int parentId){

        List<Map> maps = JSONArray.parseArray(jsonStr, Map.class);
        HashMap<Integer, Map<String, Object>> map = new HashMap<>();
        HashMap<String, Object> map1= null;
        for (Map map2:maps) {
            String name = (String) map2.get("name");
            map1 = new HashMap<>();
            map1.put("pid",map2.get("parentId"));
            map1.put("dept_name",name);
            map1.put("name_index",name);
            map.put((Integer) map2.get("id"),map1);
        }
        //获取所有子节点
        Map childTree = getChildTree(map, parentId);
        Iterator<Map.Entry<Integer,Map<String,Object>>> iterator = childTree.entrySet().iterator();
        while (iterator.hasNext()){
            Map.Entry<Integer,Map<String,Object>> next = iterator.next();
            getChildTree(childTree,next.getKey());
        }
        return map;
    }

    private static Map getChildTree(Map map,int id){
        Iterator<Map.Entry<String,Map<String,Object>>> iterator = map.entrySet().iterator();
        while (iterator.hasNext()){
            Map.Entry<String, Map<String, Object>> next = iterator.next();
            Map map1 = next.getValue();
            if(Integer.parseInt(map1.get("pid").toString())==id){
                map1.put("name_index", ((Map)map.get(id)).get("name_index")+">"+map1.get("dept_name"));
            }
        }
        return map;
    }

<think>嗯,用户想了解JavaMap.Entry的使用方法和示例。首先,我需要回忆一下Map.Entry的基本概念。Map.EntryMap接口中的内部接口,用来表示一个键值对。用户可能已经知道Map的基本用法,但想更深入地操作键值对。 接下来,我应该考虑如何创建Map.Entry实例。记得在Java 9之后,可以用Map.entry()静态方法直接创建不可变的Entry对象。例如,Map.entry("key", 1)。不过之前的版本可能需要通过Map实现类如HashMapentrySet()来获取Entry实例。需要说明这两种方法,并给出示例代码。 然后,遍历MapEntry集合是常见的操作,可以用entrySet()方法结合循环。这里需要展示如何用for-each循环或者迭代器来遍历,并获取每个Entry的键和值。同时,可以提到Java 8的forEach方法结合lambda表达式,这样代码更简洁。 修改Entry的值也是一个重点。需要注意的是,只有支持的可变Map(比如HashMap)才能通过Entry的setValue()方法修改值。TreeMap等可能有限制,需要提醒用户注意可能的异常。 用户可能还需要知道如何将Entry转换为Map,或者排序Entry集合。比如使用Stream API对Entry按值排序,然后收集成LinkedHashMap保持顺序。这部分需要给出具体的代码示例,展示如何实现排序和转换。 另外,用户提供的引用资料中提到Map.Entry可以提高代码效率和可读性,这点需要强调。比如在遍历时直接操作Entry而不是先获取键再获取值,这样更高效。同时,结合示例说明这些优势。 可能用户的实际应用场景包括数据处理、缓存实现等,可以举一些实际的例子,比如统计单词频率,然后排序输出。这样用户更容易理解如何在实际项目中应用Map.Entry。 最后,要确保回答结构清晰,分点说明,每个部分都有对应的代码示例。同时,检查LaTeX格式是否正确,数学表达式是否用$包裹,独立公式是否用$$。不过在这个问题中可能涉及数学较少,但如果有算法复杂度分析的话需要注意格式。 还需要生成相关问题,比如与性能优化、遍历方法比较、不可变Entry的使用场景等。这些问题要自然相关,帮助用户进一步学习。 总结一下,回答的结构应该是: 1. 定义和作用 2. 创建方法(包括Java 9+和之前版本) 3. 遍历方法 4. 修改值 5. 转换和排序 6. 应用场景 7. 注意事项 每个部分都附上代码示例,并引用提供的参考资料,特别是引用1、2、3中的内容,确保回答有依据。同时,语言要简洁明了,符合中文表达习惯。</think>### Java Map.Entry 使用方法及示例 #### 1. **定义与作用** `Map.Entry` 是 `Map` 接口的内部接口,表示一个键值对(key-value pair)。通过它可以直接操作 `Map` 中的单个条目,常用于遍历、修改或分析键值对数据[^3]。 --- #### 2. **创建 Map.Entry 实例** - **Java 9+**:使用 `Map.entry()` 静态工厂方法创建**不可变**的 `Entry`: ```java Map.Entry<String, Integer> entry = Map.entry("apple", 10); ``` - **传统方式**:通过 `entrySet()` 获取 `Entry` 集合: ```java Map<String, Integer> map = new HashMap<>(); map.put("apple", 10); Set<Map.Entry<String, Integer>> entries = map.entrySet(); ``` --- #### 3. **遍历 Map.Entry** 通过 `entrySet()` 遍历键值对(效率高于遍历 `keySet()`): ```java for (Map.Entry<String, Integer> entry : map.entrySet()) { String key = entry.getKey(); Integer value = entry.getValue(); System.out.println(key + " -> " + value); } ``` 或使用 Java 8 的 `forEach`: ```java map.entrySet().forEach(entry -> System.out.println(entry.getKey() + " : " + entry.getValue()) ); ``` --- #### 4. **修改 Entry 的值** 通过 `setValue()` 修改值(需确保 `Map` 支持修改): ```java Map.Entry<String, Integer> entry = Map.entry("apple", 10); // 需要将 Entry 放入 Map 后修改 Map<String, Integer> map = new HashMap<>(); map.put(entry.getKey(), entry.getValue()); map.get("apple").setValue(20); // 修改值 ``` --- #### 5. **Entry 的转换与排序** - **转换为新 Map**: ```java List<Map.Entry<String, Integer>> entries = new ArrayList<>(map.entrySet()); Map<String, Integer> newMap = entries.stream() .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue)); ``` - **按值排序**: ```java List<Map.Entry<String, Integer>> sortedEntries = new ArrayList<>(map.entrySet()); sortedEntries.sort(Map.Entry.comparingByValue(Comparator.reverseOrder())); ``` --- #### 6. **应用场景** - **数据处理**:统计词频后按频率排序输出。 - **缓存实现**:遍历缓存条目进行过期检查。 - **配置管理**:读取配置文件中的键值对。 --- #### 7. **注意事项** - 不可变 `Entry`(如 `Map.entry()` 创建)不支持 `setValue()`[^1]。 - 使用 `entrySet()` 遍历比 `keySet()` + `get()` 更高效[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值