1

我正在用 Java 开发一个项目(我很新)。

我正在尝试创建两个数组,它们引用一组相似的对象(索引 3-16)和各自的 3(索引 0-2)。我希望这些对象是堆栈(我改为“Pile”,它只有一种方法来报告它们的长度)。每个“Pile”对象都准备好接受“Piece”对象。

Pile<Piece>[] leftBoard = new Pile[16];
Pile<Piece>[] rightBoard = new Pile[16];
for (int i = 3; i < 16; i++){
    leftBoard[i] = new Pile<Piece>();
    rightBoard[i] = leftBoard[i];
}
for (int i = 0; i < 3; i++){
leftBoard[i] = new Pile<Piece>();
}
for (int i = 0; i < 3; i++){
    rightBoard[i] = new Pile<Piece>();
}

请帮忙!谢谢!

4

1 回答 1

1

Pile<Piece>[]是一个泛型数组。由于 Java 中的类型擦除,这是非常糟糕的事情™。相反,尝试这样的事情:

// Initialize arrays.
ArrayList<Pile<Piece>> leftBoard = new ArrayList<Pile<Piece>>(16);
ArrayList<Pile<Piece>> rightBoard = new ArrayList<Pile<Piece>>(16);

// Fill arrays so we can use the "set" method.
leftBoard.add(Collections.<Pile<Piece>>nCopies(null));
rightBoard.add(Collections.<Pile<Piece>>nCopies(null));

// Store values.
for (int i = 3; i < 16; i++){
    Pile<Piece> thisPiece = new Pile<Piece>();
    leftBoard.set(i, thisPiece);
    rightBoard.set(i, thisPiece);
}
for (int i = 0; i < 3; i++){
    leftBoard.set(i, new Pile<Piece>());
}
for (int i = 0; i < 3; i++){
     rightBoard.set(i, new Pile<Piece>());
}

ArrayList也更好,因为它可以动态调整大小(在许多其他方面)。

快速总结:如果你有String[] array`ArrayList 列表,那么:

  • array[i]是相同的list.get(i)
  • array[i] = var是相同的list.set(i, var)
  • 您可以将元素添加到末尾list.add(var)
  • 您可以使用list.remove(index)或从任何地方删除元素list.remove(var)
  • 有关更多信息,请参阅有关该主题的ArrayList文档Java 教程

编辑:关于不可修改列表的主题:

List<MyObject> l = Collections.unmodifiableList(myList);
l.get(0);             // valid as long as element exists
l.get(0).foo();       // valid
l.get(0).setFoo(bar); // valid
l.remove(foo);        // INVALID
l.add(foo);           // INVALID

因此,您可以操作列表中的对象,但不能修改它们在列表中的位置或列表本身的内容。想象一下处于封锁状态的监狱——没有人进出,但你仍然可以与囚犯交谈。

如果您希望Piles 保留在原处但能够移动Pieces,那么一个不可修改的列表对我来说听起来不错。只要您有类似的方法somePile.setPiece(somePiece),这应该可以正常工作。

于 2013-04-01T01:30:54.553 回答