1)一个非序列化的java对象可以通过网络发送,由另一个JVM执行,或者存储在本地文件存储中以恢复数据吗? 2)序列化和存储java对象与存储java对象没有序列化有什么区别?
发布于 2013-09-29 05:57:25
序列化是将java对象表示为一系列字节的一种方法。只是一种格式而已。“内置”java序列化是一个类,它提供了将java对象转换为一系列字节的API。就这样。当然,反序列化是一个“互补”过程,允许将这个二进制流转换回对象。
序列化/反序列化本身与“通过网络发送”无关。发送二进制流非常方便,可以通过序列化从对象创建二进制流。
更重要的是,有时内置序列化并不是获取二进制流的最佳方法,因为有时可以通过使用较少的字节来转换对象。
因此,您可以使用自定义协议,为序列化提供您自己的定制(例如,可外生)
甚至使用第三方库(如阿帕奇·阿夫罗 )
我认为这有效地回答了你们的两个问题:
希望这能有所帮助。
发布于 2013-09-29 05:51:08
简而言之,您不会在java中存储非序列化对象。所以我会对这两个问题都说不。
编辑: ObjectOutputStream和ObjectInputStream可以编写原语,也可以编写可序列化的对象,如果您正在使用这些对象的话。
发布于 2013-09-29 05:53:57
1)是否可以通过网络发送非序列化的java对象,由另一个JVM执行,或者存储在本地文件存储中以恢复数据?
使用ObjectOutputStream对对象进行封送,以便通过线路发送。序列化是存储对象状态的Java标准方法。你可以自己设计出同样的方法,但除非你以标准的方式看到一个大问题,否则再发明轮子是没有意义的。
2)序列化和存储java对象与不序列化java对象存储java对象有什么区别?
序列化使用ObjectOuputStream存储对象的状态,可以使用ObjectInputStream反序列化.序列化对象可以保存到文件中,也可以通过网络发送。序列化是实现所有这些的标准方法。但是,如果你真的有意义的话,你总是可以发明你的方法。
https://stackoverflow.com/questions/19074867
复制相似问题