提问者:小点点

序列化哈希表,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:位于sun.relect.NativeMethodAccessorImpl.invoke0(本机方法)的java.io.ObjectOutputStream.writeObject0(未知源)处的项,位于java.io.OObjectOutputStream.writeObject(未知源位于java.io.ObjectStreamClass.invokeWriteObject(未知源)位于java.io.ObjectOutputStream.writeSerialData(未知源java.io.ObjectOutputStream.writeSerialData(未知源)位于java.io.OObjectOutputStream.writeOrdinaryObject(未知源

我不确定这些错误意味着什么,或者为什么我会得到它们,甚至不知道如何修复它们。有人能帮我吗?

编辑:商店类

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保存未实现Serializable的项目对象。我现在已经修好了。程序运行和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文件中的数据。我在尝试使用该案例时收到这些错误

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)


共3个答案

匿名用户

即使 Hashtable 对象是可序列化的,存储在其中的对象也必须是可序列化的。因此,我将首先检查您存储在哈希表中的任何内容是否实现了可序列化接口。至少,Store 类还应实现可序列化接口。

更新

根据更新的问题,Item 类似乎也需要实现可序列化。事实上,这正是异常的第一行所说的:

java.io.NotSerializableException: Item

匿名用户

您只能编写Serializable的对象,您可以查找Oracle的JavaDoc以了解详细信息。

通常,在大多数情况下,您可以将<code>实现Serializable</code>添加到满足一些要求的任何类中。

一个类只能有一些字段,这些字段要么是可序列化的对象,要么是一些原始类型,如< code>int或< code>char等。

如果存在某种超类型的字段,则占据该字段的对象实例必须是可序列化的,即使该超类型不是。

还有更多内容。

匿名用户

"java.io.NotSeri的异常:项目"是说类项目是不可序列化的。它需要是可序列化的,因为地图的内容需要是可序列化的,整个地图才是可序列化的。