序列化HashTable,Java

She*_*kie 6 java serialization

我以前从未使用过序列化.我想我没事,除了我的"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();

    }
Run Code Online (Sandbox Code Playgroud)

这继续包含一堆更多的代码,但我认为真正重要的是我的"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;
Run Code Online (Sandbox Code Playgroud)

当我尝试将所有数据保存到我的.obj文件并关闭流并退出我的程序时,我得到所有这些错误......

java.io.NotSerializableException:位于java.io.ObjectOutputStream.writeObject(未知源)的java.io.ObjectOutputStream.writeObject(未知源)中的项目,位于sun.reflect.NativeMethodAccessorImpl的java.util.Hashtable.writeObject(未知源).在java.io.ObjectStreamClass的java.lang.reflect.Method.invoke(未知来源)的sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源)的sun.reflect.NativeMethodAccessorImpl.invoke(未知来源)中的invoke0(本机方法). java.io.ObjectOutputStream.defaultWriteFields上的java.io.ObjectOutputStream.writeObject0(未知来源)java.io.ObjectOutputStream.writeOrdinaryObject(未知来源)java上的invoWriteObject(未知来源) java.io.ObjectOutputStream.writeObject(Unknown Source)at java.io.ObjectOutputStream.writeOrdinaryObject(Unknown Source)at java.io.ObjectOutputStream.writeObject0(Unknown Source)at java.io.ObjectOutputStream.writeObject0(Unknown Source)at java.io.ObjectOutputStream.writeObject(Unkno)wn Source)在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;

}

 }
Run Code Online (Sandbox Code Playgroud)

**我的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;
Run Code Online (Sandbox Code Playgroud)

这种情况的目的是允许用户选择是否要使用存储在我的.obj文件中的数据.我试图使用这种情况时得到这些错误

at java.io.ObjectInputStream $ BlockDataInputStream.peekByte(Unknown Source)at java.io.ObjectInputStream.readObject0(Unknown Source)at java.io.ObjectInputStream.readObject(Unknown Source)at Test.main(Test.java:142)

Viv*_*ath 10

即使Hashtable对象是序列化的,您存储的对象里面它必须是可序列化也是如此.所以我首先要检查你的Hashtable实现Serializable界面中是否有你存储的内容.至少,您的Store类也应该实现该Serializable接口.

UPDATE

根据您更新的问题,Item该类似乎也需要实现Serializable.实际上,这正是异常的第一行所说的:

java.io.NotSerializableException: Item
Run Code Online (Sandbox Code Playgroud)

  • @ hd1 OP询问他为什么会收到这些错误......我解释了为什么以及如何解决这个问题.:) IMO这是一个答案. (3认同)
  • 从技术上讲,问题是_可以有人帮助我吗?_并且答案是"是". (3认同)