序列化HashTable,Java
我以前从未使用过序列化.我想我没事,除了我的“Q”案例切换的最后一部分.
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:Item 我不确定这些错误大多数意味着什么,或者为什么我会得到它们,甚至不知道如何修复它们.谁能帮我? 编辑:商店类 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; } } **我的HashTable包含不实现Serializable的Item对象.我现在修复了哪个.程序运行和Q案例工作正常!现在是我的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文件中的数据.我试图使用这种情况时得到这些错误 at java.io.ObjectInputStream $BlockDataInputStream.peekByte(Unknown Source) 解决方法
即使Hashtable对象是可序列化的,您存储在其中的对象也必须是可序列化的.所以我首先检查你在Hashtable中存储的内容是否实现了Serializable接口.至少,您的Store类还应该实现Serializable接口.
UPDATE 根据您更新的问题,看起来Item类也需要实现Serializable.实际上,这正是异常的第一行所说的: java.io.NotSerializableException: Item (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |