基于键修剪 ObjectNode

问题描述

我有一小段代码有问题,需要正确编写。代码如下,

  public static void doOperation(ObjectNode object,Set<String> keys) {
        object.forEach(x -> {
            if (x.isArray()) {
                x.forEach(y -> {
                    ObjectNode on = (ObjectNode) y;
                    on.remove(keys);
                    doOperation(on,keys);
                });
            } else if (x.isObject()) {
                ObjectNode on = (ObjectNode) x;
                on.remove(keys);
            }
        });
    }

清洁工作按规则进行,

  1. 如果这是 ObjectNode,请从那里删除密钥。
  2. 如果是 Array 节点,从那里获取对象并相应地清理它们 #1

我认为错误在于它不假设一个数组节点也可以包含另一个数组节点,我们需要编写另一个递归方法来最终返回 ObjectNode。

正确吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)