2

非常に基本的な質問になると思いますが、何時間も答えを探していて、コードのどこが間違っているのかわかりません。だから:私はそれを読み返すよりも、SerializableObjectと呼ばれるオブジェクトをシリアライズします。逆シリアル化メソッドで一時オブジェクトを取得し、SerializeableObject後で使用したい別の new にコピーしたいのですが、正しくコピーできませんが、一時オブジェクトは逆シリアル化で値を適切に取得しました。ここに私のクラスがあります: SeralizeableObject:

public class SerializableObject implements Serializable, Cloneable{

private Vector<int[]> mixMade;
private Vector<int[]> stepsMade;
private long time;
private int steps;
private int winnerState;

public SerializableObject(Vector<int[]> mixMade, Vector<int[]> stepsMade,
 long time, int steps, int winnerState) {
    this.mixMade = mixMade;
    this.stepsMade = stepsMade;
    this.time = time;
    this.steps = steps;
    this.winnerState = winnerState;
}

@Override
public String toString() {
    String str = "";
    for(int[] mixEl : mixMade){
        str += mixEl[0] + ", " + mixEl[1] + "|";
    }
    str += " mixes\n";
    for(int[] stepEl : stepsMade){
        str += stepEl[0] + ", " + stepEl[1] + "|";
    }
    str += " steps\n";
    str += "time: " + time + ", stepsnum: " + steps + ", 
winstate: " + winnerState;
    return str;
}    

@Override
public SerializableObject clone() {
    SerializableObject serObj;
    Vector<int[]> mixMadeTemp   = new Vector<int[]>();
    Vector<int[]> stepsMadeTemp   = new Vector<int[]>();
    for(int i = 0; i < mixMade.size(); ++i){
        mixMadeTemp.add(mixMade.get(i));
    }
    for(int i = 0; i < stepsMade.size(); ++i){
        stepsMadeTemp.add(stepsMade.get(i));
    }
    serObj = new SerializableObject(mixMadeTemp, stepsMadeTemp, 
time, steps, winnerstate);
    return serObj;
}

}

シリアライザー:

public class ObjectSerializator {

public ObjectSerializator() {

}

public void toFile(String filepath, SerializableObject serObj){
    ObjectOutputStream out;
    try{
        FileOutputStream fileOut = new FileOutputStream(filepath);
        out = new ObjectOutputStream(fileOut);
        out.writeObject(serObj);
    }catch (IOException ex) {

    }    
}

public void fromFile(String filepath, SerializableObject serObj){
    SerializableObject tempSerObj;
    try {
        FileInputStream fileIn = new FileInputStream(filepath);
        ObjectInputStream in = new ObjectInputStream(fileIn);

        tempSerObj = (SerializableObject) in.readObject();
        System.out.println(tempSerObj + "TEMP");
        serObj = tempSerObj.clone();

        in.close();
        fileIn.close();
    } catch (IOException ex) {

    } catch (ClassNotFoundException ex) {

    }
}

}

注: serobj 参照は、fromFile メソッド内の適切な値を適切に指しています。ユーザーがロード元のファイルを選択できる filechooser クラス:

public class FileChooser extends JFileChooser{

private ObjectSerializator serializator;

public FileChooser() {
    serializator = new ObjectSerializator();
}

public void load(SerializableObject serObj){
        int retValue = showOpenDialog(null);
        serializator.fromFile(getSelectedFile().getAbsolutePath(), serObj);
}}

私のメインフレームよりもボタンアクションから呼び出します

public void load(){
    SerializableObject serObj = new SerializableObject(new Vector<int[]>(), new 
Vector<int[]>(), 10, 10, 200);
    fileChooser.load(serObj);
    System.out.println(serObj + " LAST");
}

ここに私の出力があります:

3, 2|4, 3| mixes

0, 0|0, 1|0, 0| steps

time: 6000, stepsnum: 3, winstate: 0TEMP

-------------------

 mixes

 steps

time: 10, stepsnum: 10, winstate: 200 LAST
4

1 に答える 1

1

逆シリアル化したオブジェクトは失われます。

fromFileメソッドには、次の行があります。

serObj = tempSerObj.clone();

しかしserObj、メソッドへの引数です。上記の行はローカル serObj変数を変更しますが、元のオブジェクトはそのまま残ります。呼び出し元のメソッド ( load) は、古い (元の) オブジェクトへの参照を保持しています。

メソッドは aを引数としてfromFile受け入れるべきではありません。SerializableObjectむしろ、1 を返す必要があります。次に、FileChooser.loadメソッドもそれを返す必要があります。最後に、loadメイン フレームのメソッドは次のようになります。

public void load() {
    SerializableObject originalObject = new SerializableObject(new Vector<int[]>(), new Vector<int[]>(), 10, 10, 200);
    // Here you can do something with the newly created object, such as save it to a file.

    SerializableObject deserializedObject = fileChooser.load();
    System.out.println(deserializedObject + " LAST");
}
于 2012-04-10T11:52:40.237 に答える