面试题:如何实现Java的序列化?
答案:序列化一个对象还是比较简单的,只要让它实现serializable接口就行了。但是,当余元引入序列化概念之后,它的很多标准类库的类,包括primitive的wrapper类、所有的容器类,以及别的很多类,都会相应的发生改变,甚至连class对象都会被序列化。
要想序列化对象,必须先创建一个outputstream,然后把它嵌进objectoutputstream。这时就能用writeobject()方法把对象写入outputstream,。读的时候需要把inputstream嵌到objectinputstream中,然后在调用readobject()方法。不过这样读出来的只是一个object的reference,因此,在用之前,还得线下传。对象序列化不仅能保存对象的副本,而且还会跟着对象中reference把它所引用的对象也保存起来,然后再继续跟踪那些对象的reference,以此类推。这种情形常被称为“单个对象所连接的‘对象网’”。这个机制所涵盖的范围不仅包括对象的成员数据,而且还包含数组里面的reference。如果要自己实现对象序列化,那么编写跟踪这些链接的程序将会是一件非常痛苦的任务。但是,Java的对象序列化就能准确无误地做到这一点,毫无疑问,它的遍历算法是做过优化的。
知识拓展:Java的“对象序列化”能将一个是想了serializable接口的对象转换成一组byte,这样日后要用这个对象的时候,就能把这些byte数据恢复出来,并据此重新构建那个对象。这一点甚至在扩网络的环境下也是如此,这就意味着序列化机制能自动补偿操作系统方面的差异。也就是说,可以在Windows创建一个对象,序列化之后,在他通过网络传到Unix上,然后在哪里进行重建。不用担心在不同的平台上数据是怎样表示的,以及byte顺序怎样,或者别的什么细节。
对象序列化能实现“轻量级的persistence”。所谓的persistence,是指对象的生命周期不是由程序是否运行决定的,在程序的两次调用之间对象仍然还活着。通过“将做过序列化处理的对象写入磁盘,等到程序再次运行的时候再把它读出来”,可以达到persistence的效果。之所以说“轻量级”,是以内不能用想“persistent”这样的关键词来直接定义一个对象,然后让系统去处理所有的细节。相反,必须明确的进行序列化和解序列化。
之所以要在语言里加入对象序列化,是因为要用它来实现两个重要的功能。Java的远程方法调用能像调用自己机器上的对象那样去调用其他机器上的对象。当向远程对象传递消息的时候,就需要通过对象序列化来传送参数和返回值。对Java Bean来说,对象序列化也是必不可少的。Bean的状态信息通常实在设计时配置的,这些状态信息必须保存起来,供程序启动的时候用,对象序列化就负责这个工作。
更多,Java视频,Java教程尽在极悦Java培训,关注极悦官方微信,获得一手Java面试题。