【发布时间】:2013-04-17 01:51:37
【问题描述】:
我以前从未使用过序列化。除了“Q” case-switch 中的最后一部分,我想我一切都好。
public class Test{
public static void main(String args[]){
Store store = new Store();
FileOutputStream fos;
ObjectOutputStream oos = null;
try{
fos = new FileOutputStream(new File("table.obj"));
oos = new ObjectOutputStream(fos);
}catch(IOException e1){
e1.printStackTrace();
}
这继续包含更多代码,但我认为真正重要的是我的“Q”案例......
case "Q":
System.out.println("Good-Bye!");
try{
oos.writeObject(store);
oos.flush();
oos.close();
}catch(IOException e){
e.printStackTrace();
}
System.exit(0);
break;
当我尝试将所有数据保存到我的 .obj 文件并关闭流并退出我的程序时,我得到了所有这些错误...
java.io.NotSerializableException:项目 在 java.io.ObjectOutputStream.writeObject0(未知来源) 在 java.io.ObjectOutputStream.writeObject(未知来源) 在 java.util.Hashtable.writeObject(未知来源) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(未知来源) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源) 在 java.lang.reflect.Method.invoke(未知来源) 在 java.io.ObjectStreamClass.invokeWriteObject(未知来源) 在 java.io.ObjectOutputStream.writeSerialData(未知来源) 在 java.io.ObjectOutputStream.writeOrdinaryObject(未知来源) 在 java.io.ObjectOutputStream.writeObject0(未知来源) 在 java.io.ObjectOutputStream.defaultWriteFields(未知来源) 在 java.io.ObjectOutputStream.writeSerialData(未知来源) 在 java.io.ObjectOutputStream.writeOrdinaryObject(未知来源) 在 java.io.ObjectOutputStream.writeObject0(未知来源) 在 java.io.ObjectOutputStream.writeObject(未知来源) 在 Test.main(Test.java:143)
我不确定这些错误中的大多数是什么意思,或者我为什么会遇到这些错误,甚至不确定如何修复它们。谁能帮帮我?
编辑:存储类
import java.io.Serializable;
import java.util.Hashtable;
public class Store implements Serializable{
Hashtable<String, Item> stockedItems = new Hashtable<String, Item>();
public boolean addItem(String code){
if(stockedItems.containsKey(code)){
stockedItems.get(code).incrementQuantity();
return true;
}
return false;
}
public boolean removeItem(String code){
if(stockedItems.containsKey(code)){
stockedItems.get(code).decrementQuantity();
return true;
}
return false;
}
public boolean findItem(String code){
if(stockedItems.containsKey(code)){
return true;
}
return false;
}
}
**My HashTable 包含未实现可序列化的项目对象。我现在修复了。程序运行,Q case 工作正常!现在是我的 U 案例不起作用,这里是......
case "U":
try{
FileInputStream fis = new FileInputStream("table.obj");
ObjectInputStream ois = new ObjectInputStream(fis);
store = (Store)ois.readObject();
ois.close();
}catch(IOException | ClassNotFoundException e){
e.printStackTrace();
}
break;
本案例的目的是让用户选择是否要使用存储在我的 .obj 文件中的数据。我在尝试使用该案例时遇到这些错误
在 java.io.ObjectInputStream$BlockDataInputStream.peekByte(Unknown Source) 在 java.io.ObjectInputStream.readObject0(未知来源) 在 java.io.ObjectInputStream.readObject(未知来源) 在 Test.main(Test.java:142)
【问题讨论】:
-
你能发布Store类吗?我的猜测是它没有被标记为可序列化或者里面的东西是不可序列化的。
-
您尝试存储的对象是否可序列化?
-
NotSerializableException表示您正在尝试序列化不可序列化的内容。显示您的Store班级... -
我根本看不到
Hashtable...那么Store类呢?
标签: java serialization