package com.cjonline.foundation.authority.pojo; import java.util.ArrayList; import java.util.Collections; import java.util.Iterator; import java.util.List; import org.apache.log4j.Logger; import com.cjonline.foundation.util.CheckNullEmpty; /** * 实现递归的帮助类,最终的结果可以描述成如下: * 根(root) * --1(子系统1) * -----1.1 * -------1.1.1 * -------1.1.2 * ------- .... * -----1.2 * --2(子系统2) * -----2.1 * -------2.1.1 * -------2.1.2 * ------- .... * -----2.2 */ public class ModelList implements java.io.Serializable { private static final Logger logger = Logger.getLogger(ModelList.class); private static final long serialVersionUID = 6384598893693849820L; /** * model代表当前模块 */ private SysModel model; /** * models代表当前模块下面的子模块, */ private List<ModelList> subList = new ArrayList<ModelList>(); /** * 菜单级别 */ private int flag = 0; public SysModel getModel() { return model; } public void setModel(SysModel model) { this.model = model; } public List<ModelList> getSubList() { return subList; } public void setSubList(List<ModelList> subList) { this.subList = subList; } public void setFlag(int flag) { this.flag = flag; } public int getFlag() { return flag; } /** * 递归方法根据传入的模块集合形成层级菜单 */ @SuppressWarnings("unchecked") public ModelList createTree2(List<SysModel> ms) { // ModelList node = new ModelList(); ArrayList<SysModel> fu = new ArrayList<SysModel>();// 用来存储parentId为空的父节点; ArrayList<SysModel> childs = new ArrayList<SysModel>();// 用来存储不是系统的模块 // 将系统和模块菜单分开 for (Iterator<SysModel> it = ms.iterator(); it.hasNext();) { SysModel mode = (SysModel) it.next(); String parentId = mode.getParentId(); if (parentId == null || parentId.equals("")) { fu.add(mode); } else { childs.add(mode); } } //由于是多个子系统,首先要找出有多少个子系统 for (SysModel model : fu) { ModelList node1 = new ModelList(); node1.setFlag(0); node1.setModel(model); node.subList.add(node1); appendChild(node1, childs); } return node; } /** * node节点 childs为所以系统下的子节点 */ public void appendChild(ModelList node, List<SysModel> childs) { if (node != null) { String systemId = node.getModel().getSystemId(); String smid = node.getModel().getSysModuleId(); int flag = node.getFlag(); if (childs != null && childs.size() > 0) { for (SysModel model : childs) { String systemId2 = model.getSystemId(); String parentId2 = model.getParentId(); if (systemId.equals(systemId2)) { if (parentId2.equals(smid)) { ModelList child = new ModelList(); child.setModel(model); child.setFlag(flag + 1); node.getSubList().add(child); appendChild(child, childs); } } } } } } }
更多java遞歸選單樹轉換成pojo物件相關文章請關注PHP中文網!

JVMmanagesgarbagecollectionacrossplatformseffectivelybyusingagenerationalapproachandadaptingtoOSandhardwaredifferences.ItemploysvariouscollectorslikeSerial,Parallel,CMS,andG1,eachsuitedfordifferentscenarios.Performancecanbetunedwithflagslike-XX:NewRa

Java代碼可以在不同操作系統上無需修改即可運行,這是因為Java的“一次編寫,到處運行”哲學,由Java虛擬機(JVM)實現。 JVM作為編譯後的Java字節碼與操作系統之間的中介,將字節碼翻譯成特定機器指令,確保程序在任何安裝了JVM的平台上都能獨立運行。

Java程序的編譯和執行通過字節碼和JVM實現平台獨立性。 1)編寫Java源碼並編譯成字節碼。 2)使用JVM在任何平台上執行字節碼,確保代碼的跨平台運行。

Java性能与硬件架构密切相关,理解这种关系可以显著提升编程能力。1)JVM通过JIT编译将Java字节码转换为机器指令,受CPU架构影响。2)内存管理和垃圾回收受RAM和内存总线速度影响。3)缓存和分支预测优化Java代码执行。4)多线程和并行处理在多核系统上提升性能。

使用原生庫會破壞Java的平台獨立性,因為這些庫需要為每個操作系統單獨編譯。 1)原生庫通過JNI與Java交互,提供Java無法直接實現的功能。 2)使用原生庫增加了項目複雜性,需要為不同平台管理庫文件。 3)雖然原生庫能提高性能,但應謹慎使用並進行跨平台測試。

JVM通過JavaNativeInterface(JNI)和Java標準庫處理操作系統API差異:1.JNI允許Java代碼調用本地代碼,直接與操作系統API交互。 2.Java標準庫提供統一API,內部映射到不同操作系統API,確保代碼跨平台運行。

modularitydoesnotdirectlyaffectJava'splatformindependence.Java'splatformindependenceismaintainedbytheJVM,butmodularityinfluencesapplicationstructureandmanagement,indirectlyimpactingplatformindependence.1)Deploymentanddistributionbecomemoreefficientwi

BytecodeinJavaistheintermediaterepresentationthatenablesplatformindependence.1)Javacodeiscompiledintobytecodestoredin.classfiles.2)TheJVMinterpretsorcompilesthisbytecodeintomachinecodeatruntime,allowingthesamebytecodetorunonanydevicewithaJVM,thusfulf


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版
SublimeText3 Linux最新版

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。