【问题标题】:Serializing a HashTable, Java序列化哈希表,Java
【发布时间】: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


【解决方案1】:

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

更新

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

java.io.NotSerializableException: Item

【讨论】:

  • 这更像是一个评论而不是一个答案,IMO
  • @hd1 OP 问他为什么会收到这些错误...我解释了为什么以及如何解决它。 :) IMO 这是一个答案。
  • IMO,这不是一个答案,但我们必须同意不同意
  • 技术上的问题是谁能帮助我?答案是yes
  • 我也会这样回答的。
【解决方案2】:

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

一般来说,在大多数情况下,您可以将implements Serializable 添加到满足一些要求的任何类中。

一个类只能具有本身是可序列化对象或某些原始类型(如intchar 等)的字段。

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

还有很多。

【讨论】:

    【解决方案3】:

    "java.io.NotSerializableException: Item" 表示class Item 不可序列化。它需要可序列化,因为地图的内容需要可序列化才能使整个地图可序列化。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2015-03-12
      • 2013-06-25
      • 2013-03-16
      • 2016-11-16
      • 1970-01-01
      • 1970-01-01
      • 2022-01-05
      相关资源
      最近更新 更多