java getchild_Java ZkClient.getChildren方法代码示例

import org.apache.helix.manager.zk.ZkClient; //导入方法依赖的package包/类

private static void zkCopy(ZkClient srcClient, String srcRootPath, ZkClient dstClient, String dstRootPath) {

// Strip off tailing "/"

if (!srcRootPath.equals("/") && srcRootPath.endsWith("/")) {

srcRootPath = srcRootPath.substring(0, srcRootPath.length() - 1);

}

if (!dstRootPath.equals("/") && dstRootPath.endsWith("/")) {

dstRootPath = dstRootPath.substring(0, dstRootPath.length() - 1);

}

// Validate paths

PathUtils.validatePath(srcRootPath);

PathUtils.validatePath(dstRootPath);

if (srcRootPath.equals(dstRootPath)) {

logger.info("srcPath == dstPath. Skip copying");

return;

}

if (srcRootPath.startsWith(dstRootPath) || dstRootPath.startsWith(srcRootPath)) {

throw new IllegalArgumentException(

"srcPath/dstPath can't be prefix of dstPath/srcPath, was srcPath: " + srcRootPath

+ ", dstPath: " + dstRootPath);

}

// Recursive copy using BFS

List queue = new LinkedList();

String root = "";

copy(srcClient, srcRootPath, dstClient, dstRootPath, Arrays.asList(root));

queue.add(root);

while (!queue.isEmpty()) {

String path = queue.remove(0);

String fromPath = concatenate(srcRootPath, path);

List children = srcClient.getChildren(fromPath);

List paths = new ArrayList();

if (children != null && children.size() > 0) {

for (String child : children) {

String childPath = concatenate(path, child);

paths.add(childPath);

}

copy(srcClient, srcRootPath, dstClient, dstRootPath, paths);

queue.addAll(paths);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值