91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java怎么使用HashMap存取鍵值映射關系

發布時間:2023-05-12 11:13:46 來源:億速云 閱讀:96 作者:iii 欄目:編程語言

本篇內容介紹了“java怎么使用HashMap存取鍵值映射關系”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

使用HashMap存取鍵值映射關系

簡單來說,HashMap由數組和鏈表組成的,數組是HashMap的主體,鏈表則是主要為了解決哈希沖突而存在的。如果定位到的數組位置不含鏈表,那么查找、添加等操作很快,僅需一次尋址即可,其時間復雜度為O(1);如果定位到的數組包含鏈表,對于添加操作,其時間復雜度為O(n)——首先遍歷鏈表,存在即覆蓋,不存在則新增;對于查找操作來講,仍需要遍歷鏈表,然后通過key對象的equals方法逐一對比查找。從性能上考慮,HashMap中的鏈表出現越少,即哈希沖突越少,性能也就越好。所以,在日常編碼中,可以使用HashMap存取鍵值映射關系。

案例:給定菜單記錄列表,每條菜單記錄中包含父菜單標識(根菜單的父菜單標識為null),構建出整個菜單樹。

/** 菜單DO類 */@Setter@Getter@ToStringpublic static class MenuDO {    /** 菜單標識 */
    private Long id;    /** 菜單父標識 */
    private Long parentId;    /** 菜單名稱 */
    private String name;    /** 菜單鏈接 */
    private String url;
}/** 菜單VO類 */@Setter@Getter@ToStringpublic static class MenuVO {    /** 菜單標識 */
    private Long id;    /** 菜單名稱 */
    private String name;    /** 菜單鏈接 */
    private String url;    /** 子菜單列表 */
    private List<MenuVO> childList;
}/** 構建菜單樹函數 */public static List<MenuVO> buildMenuTree(List<MenuDO> menuList) {    // 檢查列表為空
    if (CollectionUtils.isEmpty(menuList)) {        return Collections.emptyList();
    }    // 依次處理菜單
    int menuSize = menuList.size();
    List<MenuVO> rootList = new ArrayList<>(menuSize);
    Map<Long, MenuVO> menuMap = new HashMap<>(menuSize);    for (MenuDO menuDO : menuList) {        // 賦值菜單對象
        Long menuId = menuDO.getId();
        MenuVO menu = menuMap.get(menuId);        if (Objects.isNull(menu)) {
            menu = new MenuVO();
            menu.setChildList(new ArrayList<>());
            menuMap.put(menuId, menu);
        }
        menu.setId(menuDO.getId());
        menu.setName(menuDO.getName());
        menu.setUrl(menuDO.getUrl());        // 根據父標識處理
        Long parentId = menuDO.getParentId();        if (Objects.nonNull(parentId)) {            // 構建父菜單對象
            MenuVO parentMenu = menuMap.get(parentId);            if (Objects.isNull(parentMenu)) {
                parentMenu = new MenuVO();
                parentMenu.setId(parentId);
                parentMenu.setChildList(new ArrayList<>());
                menuMap.put(parentId, parentMenu);
            }            
            // 添加子菜單對象
            parentMenu.getChildList().add(menu);
        } else {            // 添加根菜單對象
            rootList.add(menu);
        }
    }    // 返回根菜單列表
    return rootList;
}

“java怎么使用HashMap存取鍵值映射關系”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

治县。| 平度市| 太保市| 靖州| 克东县| 浪卡子县| 梁平县| 孟津县| 大同市| 马边| 伊宁县| 弥勒县| 昌邑市| 沈丘县| 松桃| 黎川县| 宁武县| 慈利县| 伊宁市| 闽侯县| 潮州市| 高平市| 出国| 沙坪坝区| 长阳| 盐津县| 福泉市| 兴仁县| 陕西省| 株洲县| 鱼台县| 曲阜市| 咸宁市| 耒阳市| 繁昌县| 广西| 张家界市| 庆元县| 花莲市| 神农架林区| 铜梁县|