我设法将包含JTextArea和几个按钮的非常基本的GUI对象序列化为文件'test.ser'。
现在,我想从'test.ser'中完全恢复以前保存的状态,但似乎对如何正确反序列化对象状态有误解。
班级 MyFrame 会创建JFrame并对其进行序列化。
public class MyFrame extends JFrame implements ActionListener {
// Fields
JTextArea textArea;
String title;
static MyFrame gui = new MyFrame();
private static final long serialVersionUID = 1125762532137824262L;
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
gui.run();
}
// parameterless default contructor
public MyFrame() {
}
// constructor with title
public MyFrame(String title) {
}
// creates Frame and its Layout
public void run() {
JFrame frame = new JFrame(title);
JPanel panel_01 = new JPanel();
JPanel panel_02 = new JPanel();
JTextArea textArea = new JTextArea(20, 22);
textArea.setLineWrap(true);
JScrollPane scrollPane = new JScrollPane(textArea);
scrollPane.setVerticalScrollBarPolicy(ScrollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED);
panel_01.add(scrollPane);
// Buttons
JButton saveButton = new JButton("Save");
saveButton.addActionListener(this);
JButton loadButton = new JButton("Load");
loadButton.addActionListener(this);
panel_02.add(loadButton);
panel_02.add(saveButton);
// Layout
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.getContentPane().add(BorderLayout.CENTER, panel_01);
frame.getContentPane().add(BorderLayout.SOUTH, panel_02);
frame.setSize(300, 400);
frame.setVisible(true);
}
/*
*
*/
public void serialize() {
try {
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("test.ser"));
oos.writeObject(gui);
oos.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
public void actionPerformed(ActionEvent ev) {
System.out.println("Action received!");
gui.serialize();
}
}
这里我尝试进行反序列化:
public class Deserialize {
static Deserialize ds;
static MyFrame frame;
public static void main(String[] args) {
try {
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.ser"));
frame = (MyFrame) ois.readObject();
ois.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
也许有人能指出我误解的方向?
你们怎么写一个类,它将以前序列化的gui-elements反序列化并恢复到之前的序列化状态?
我现在这样做的方式似乎在其概念中存在不止一个缺陷,对吧?
答案 0 :(得分:1)
会发生什么?你有例外吗?从代码ds
的外观来看,永远不会初始化。我相信,一旦反序列化,您将需要使用frame.setVisible(true);
显示框架。与往常一样,Swing(实际上是AWT)应仅用于AWT事件调度线程(EDT) - 使用java.awt.EventQueue.invokeLater
。
一般来说使用静力学并不是一个好主意。也不是序列化GUI组件。 final
很好,并且在大多数情况下会确保初始化实例和静态字段。
答案 1 :(得分:0)
如每个javadoc swing组件中所述,序列化JFrame和其他JFoo的首选方法是XMLEncoder。
经典序列化适用于一些小型GUI应用程序,但不适用于长寿命GUI组件应用程序。