具有原始类型的 Java 克隆类

mid*_*ode 1 java clone

我正在尝试创建一个Object(称为State)的深层副本,以对其中的一个实例进行修改,然后使用State基于新的修改旧实例的代码进行后续操作State

这是State

public class State implements Cloneable {

    // 0: empty
    // 1: white
    // 2: black
    private int[][] board;

    private int player;

    public State(int[][] board, int player) {
        this.board = board;
        this.player = player;
    }

    public int[][] getBoard() {
        return board;
    }

    public int getPlayer() {
        return player;
    }

    public void setBoard(int[][] board) {
        this.board = board;
    }

    public void setPlayer(int player) {
        this.player = player;
    }

    @Override
    protected Object clone() throws CloneNotSupportedException {
        return super.clone();
    }

}
Run Code Online (Sandbox Code Playgroud)

然后,这是我尝试访问它的方法:

State temp = (State) s.clone();
Action act = determineAction(temp);
doSomething(s, act);
Run Code Online (Sandbox Code Playgroud)

sState传递到方法中的。determineAction调用后,由于某种原因,尽管没有通过,但boardins正在被修改......这是怎么回事?temp难道不应该调用.clone()克隆所有原始类型的实例,以便可以唯一地修改它们吗?

这就是这篇文章的建议: http://howtodoinjava.com/core-java/cloning/a-guide-to-object-cloning-in-java/

我很难理解为什么这不会被深度复制,以及为什么我对 的修改temp也会修改s.

任何提示将不胜感激 - 谢谢!

编辑 - 对于任何好奇的人,以下是修复它的方法:

@Override
protected Object clone() throws CloneNotSupportedException {

    State cloned = (State) super.clone();

    int[][] clonedBoard = new int[8][8];

    for (int i = 0; i < 8; i++) {
        for (int j = 0; j < 8; j++) {
            clonedBoard[i][j] = board[i][j];
        }
    }

    cloned.setBoard(clonedBoard);

    return cloned;
}
Run Code Online (Sandbox Code Playgroud)

Thi*_*ilo 5

super.clone()不进行深度复制,并且 anint[][]不是原始类型。

它适用于 ,int player因为这是一个原始类型,一个简单的副本(由 完成Object#clone)就足够了。

你需要(深度)复制你int[][]自己。