0

我正在尝试递归运行我的方法。在方法的每次迭代中,我都会创建新的ArrayList并填充一些值并检查if运算符中的一些条件。如果为真,将再次运行此方法。如果它是假的,我想退出当前的方法迭代,并在之前的方法迭代中使用ArrayList. 在实践中,当我的条件为假并进入我的方法的先前迭代时,我使用相同的ArrayList. 这很糟糕。

我如何ArrayList为方法的每次迭代创建每个实例,以及在上一个方法中使用该迭代的实例时返回时如何工作ArrayList

我的代码:

    private List<List<String>> letsTry(List<List<ProbableValue>>
probableValues, List<List<String>> data) {

     List<List<String>> copyOfData = new ArrayList<List<String>>(data);
     List<List<ProbableValue>> copyOfProbableValues = 
                           new ArrayList<List<ProbableValue>>(probableValues);

    ProbableValue minPV = getMinPV(copyOfProbableValues);

    Set<String> pValues = new HashSet<String>(minPV.getProbableValues());
    int i = minPV.getI();
    int j = minPV.getJ();


    for (String v : pValues) {

        if (checker.canSetOnTable(copyOfProbableValues, minPV)) {
            if (!SUtils.isItsNumber(copyOfData.get(i).get(j))) {
                copyOfData.get(i).set(j, v);

          copyOfProbableValues.get(i).get(j).getProbableValues().clear();
          checker.removeProbableValue(copyOfProbableValues, v, i, j);

            }
          letsTry(new ArrayList<List<ProbableValue>>(copyOfProbableValues),
                    new ArrayList<List<String>>(copyOfData));

        }

    }

    return copyOfData;

}
4

1 回答 1

1

您似乎正在创建包含列表的列表的浅表副本。因此,只会复制嵌套列表的引用。如果你想要一个完整的深度副本,你必须做这样的事情:

List<List<String>> copyOfData = new ArrayList<List<String>>();
for (int i = 0; i < data.size(); i++) {
    copyOfData.add(new ArrayList<String>());
    for (String s : data.get(i)) {
        copyOfData.get(i).add(s);
    }
}

List<List<ProbableValue>> copyOfProbableData = new ArrayList<List<ProbableValue>>();
for (int i = 0; i < probableValues.size(); i++) {
    copyOfProbableData.add(new ArrayList<ProbableValue>());
    for (ProbableValue p : probableValues.get(i)) {
        ProbableValue pNew = new ProbableValue();

        // copy your object here

        copyOfProbableData.get(i).add(pNew);
    }
}
于 2013-03-09T20:36:26.720 回答