小马真的菜 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 C++对比不同编码下相同字符串
  • ¥15 pyqt5设计界面控件之间的空白想消除
  • ¥15 想请教大家关于机器学习的问题
  • ¥15 虚幻UE保存Actor位置失败
  • ¥15 多个.nii合并为.nii.gz格式
  • ¥50 现在需要统计2023年全年 “签收时间(qssj)” 到 “提交时间(tjsj)” 小于半小时的业务量,但是要排除掉周末的时间,同时还要排除中午休息的时间。
  • ¥50 opencv模板匹配为何图像差别大仍然匹配数值高?
  • ¥15 如何成功完成主菜单和分菜单的代码编程C++
  • ¥15 怎样采集或者其它途径拿到全国最新个体工商户数据
  • ¥20 我是一名大学生,想学习java是自学还是报培训班呢