小马真的菜 2021-03-18 10:33 采纳率: 100%
浏览 60
已采纳

Java遍历Zookeeper

求助想遍历zk,获取所有节点数据,怎么写一个方法获取呀。

在成员变量放置集合,实在浪费空间,并不优雅。想在方法上直接返回集合。求助,怎么优化代码。

或者给出一个可以遍历zk的参考方法。

package com.example.demo;
 
import java.util.ArrayList;
import java.util.List;
 
public class test {
    private List dataList = new ArrayList<>();
    /**
     * 递归遍历zk数据
     * @param path
     */
    public void backupData(String path){
        //1:根据path查询节点数据,得到nodeData
        //2:查询其子节点列表,得到childNodeList
        dataList.add(nodeData);
        if(chileNodeList==null ||chileNodeList.isEmpty()){
            return ;
        }
        //遍历子节点
        for(String node:chileNodeList){
            //3:拼接路径
            String childNodePath = path+"/"+node;
            //4:递归
            backupData(childNodePath);
        }
    }
}
  • 写回答

2条回答 默认 最新

  • 关注

    zookeeper 的数据结构是个树状结构,这个问题本质是对树的遍历。我写了一个深度优先遍历,供题主参考。

    package com.example.demo;
    
    import java.util.ArrayList;
    import java.util.List;
    
    public class test {
    
    
        /**
         * 递归遍历zk数据
         * @param path
         */
        public void backupData(String path){
            List dataList = new LinkedList<>();
            //1:根据path查询节点数据,得到nodeData
            //2:查询其子节点列表,得到childNodeList
            appendNodeData(path,dataList);
            return dataList;
        }
    
    
        /**
        * 根据路径获取当前节点
        */
        private List appendNodeData(String path,List dataList){
            if(path != null){
                 NodeData node = getNodeDataByPath(path);
                 if(node != null){
                    dataList.add(node);
                    List<String> childPaths = node.getChildPaths();
                    if(childPaths != null && childPaths.size() > 0){
                        childPaths.forEach((childPath) -> {
                             appendNodeData(childPath, dataList);
                        })
                    }
                 }
            }
            return dataList;
        }
    
    }
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵