对象序列化机制的理解
生活随笔
收集整理的这篇文章主要介绍了
对象序列化机制的理解
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
1.对象的序列化机制:
对象序列化机制允许把内存中的Java对象转换成平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点。
//当其它程序获取了这种二进制流,就可以恢复成原来的Java对象。
即序列化过程 / 反序列化过程:
序列化过程: 将内存中的java对象保存到磁盘中或通过网络传输出去,使用ObjectOutputStream实现;
反序列化过程: 将磁盘文件中的对象还原为内存中的java对象;使用ObjectInputStream实现;
2.对象要想实现序列化,需要满足的条件?
a. 实现接口:Serializable 标识接口
b. 对象所在的类提供常量:序列版本号serialVersionUID (public static final long);
c. 要求对象的属性也必须是可序列化的。(基本数据类型、String:本身就是可序列化的);
tips:ObjectInputStream / ObjectOutputStream不能序列化static和transient修饰的成员变量。
tips:开发中一般都用String实现序列化。
序列化过程代码实现:
/*序列化过程:将内存中的java对象保存到磁盘中或通过网络传输出去使用ObjectOutputStream实现*/@Testpublic void testObjectOutputStream(){ObjectOutputStream oos = null;try {//1.oos = new ObjectOutputStream((new FileOutputStream(new File("Object.dat"))));//2.oos.writeObject(new String("Beijing"));oos.writeObject(new Person("Tom",23));oos.flush();oos.flush();//刷新操作} catch (IOException e) {e.printStackTrace();} finally {//3.try {oos.close();} catch (IOException e) {e.printStackTrace();}}}反序列化过程代码实现:
/*反序列化:将磁盘文件中的对象还原为内存中的java对象使用ObjectInputStream实现*/@Testpublic void testObjectInputStream(){ObjectInputStream ois = null;try {ois = new ObjectInputStream(new FileInputStream("Object.dat"));Object obj = ois.readObject();String str = (String)obj;Person p = (Person)ois.readObject();System.out.println(str);System.out.println(p);} catch (IOException e) {e.printStackTrace();} catch (ClassNotFoundException e) {e.printStackTrace();} finally {try {ois.close();} catch (IOException e) {e.printStackTrace();}}}总结
以上是生活随笔为你收集整理的对象序列化机制的理解的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: struts2标签循环输出tr和td
- 下一篇: API验证