首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java序列化对象与非序列化对象

Java序列化对象与非序列化对象
EN

Stack Overflow用户
提问于 2013-09-29 05:47:06
回答 4查看 2.8K关注 0票数 3

1)一个非序列化的java对象可以通过网络发送,由另一个JVM执行,或者存储在本地文件存储中以恢复数据吗? 2)序列化和存储java对象与存储java对象没有序列化有什么区别?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-09-29 05:57:25

序列化是将java对象表示为一系列字节的一种方法。只是一种格式而已。“内置”java序列化是一个类,它提供了将java对象转换为一系列字节的API。就这样。当然,反序列化是一个“互补”过程,允许将这个二进制流转换回对象。

序列化/反序列化本身与“通过网络发送”无关。发送二进制流非常方便,可以通过序列化从对象创建二进制流。

更重要的是,有时内置序列化并不是获取二进制流的最佳方法,因为有时可以通过使用较少的字节来转换对象。

因此,您可以使用自定义协议,为序列化提供您自己的定制(例如,可外生)

甚至使用第三方库(如阿帕奇·阿夫罗 )

我认为这有效地回答了你们的两个问题:

  1. 如果需要,您可以自己将非序列化对象(我猜不实现“可序列化”接口的对象)转换为一系列字节(字节流),然后通过网络发送它,存储在二进制文件中。当然,您必须了解如何读取这种二进制格式来进行转换。
  2. 由于序列化只是一种转换协议,而不是“与存储相关的东西”,所以答案是显而易见的。

希望这能有所帮助。

票数 4
EN

Stack Overflow用户

发布于 2013-09-29 05:51:08

简而言之,您不会在java中存储非序列化对象。所以我会对这两个问题都说不。

编辑: ObjectOutputStream和ObjectInputStream可以编写原语,也可以编写可序列化的对象,如果您正在使用这些对象的话。

票数 1
EN

Stack Overflow用户

发布于 2013-09-29 05:53:57

1)是否可以通过网络发送非序列化的java对象,由另一个JVM执行,或者存储在本地文件存储中以恢复数据?

使用ObjectOutputStream对对象进行封送,以便通过线路发送。序列化是存储对象状态的Java标准方法。你可以自己设计出同样的方法,但除非你以标准的方式看到一个大问题,否则再发明轮子是没有意义的。

2)序列化和存储java对象与不序列化java对象存储java对象有什么区别?

序列化使用ObjectOuputStream存储对象的状态,可以使用ObjectInputStream反序列化.序列化对象可以保存到文件中,也可以通过网络发送。序列化是实现所有这些的标准方法。但是,如果你真的有意义的话,你总是可以发明你的方法。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19074867

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档