一般来说,反序列化时,我们如果是json或者xml,则可以用对应的插件来做,但是如果用到了jdk库中自带的序列化API,那就需要注意了,如果我们的文件(如二进制文件)比较大,或者其他因素,就会导致文件反序列化是时比较慢,我在工作中遇到的情况是:反序列化一个二进制文件花了13秒,太久了,大概代码如下:
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(
new File("E:/Person.txt")));
Person person = (Person) ois.readObject();
System.out.println("Person对象反序列化成功!");
这种就是一般的反序列化的方法,一般情况下可以这样,但是,如果出现文件比较大,加上本生服务器就不太流畅,那么就会导致反序列化缓慢的问题,这里只要加上BufferedInputStream,问题就迎刃而解了,修改后的代码如下:
BufferedInputStream bis = new BufferedInputStream(new FileInputStream( new File("E:/Person.txt")));
ObjectInputStream ois = new ObjectInputStream(bis);
Person person = (Person) ois.readObject();
System.out.println("Person对象反序列化成功!");
加上BufferedInputStream这个缓冲输入流,使得I/O调用减少至少8倍。在反序列化时快了很多。
这里只是一个小例子,其实在任何文件的I/O中,加入BufferedInputStream或者BufferedOutputStream这样的缓冲流,都可以起到提速的作用。