阿里___Java对象的序列化
2016-07-27 16:15
411 查看
今天也被问到如何进行序列化,我一时懵逼,觉得是让我实现一个库,后来我找了一下网上资料,所谓的对象的序列化大概意思就是实现一个接口而已。。。
不知道是不是面试官的问题。
代码参考 https://github.com/AceXIE/Serializable-example
下面引用一段话。
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。
只能将支持 java.io.Serializable 接口的对象写入流中。每个 serializable 对象的类都被编码,编码内容包括类名和类签名、对象的字段值和数组值,以及从初始对象中引用的其他所有对象的闭包。
1.概念
序列化:把Java对象转换为字节序列的过程。
反序列化:把字节序列恢复为Java对象的过程。
2.用途
对象的序列化主要有两种用途:
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
3.对象序列化
3.1序列化API
java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。
java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。
3.2代码示例
4.说明
读取对象的顺序与写入时的顺序要一致。
对象的默认序列化机制写入的内容是:对象的类,类签名,以及非瞬态和非静态字段的值。
下一篇
http://blog.csdn.net/xkzju2010/article/details/52061451
不知道是不是面试官的问题。
代码参考 https://github.com/AceXIE/Serializable-example
下面引用一段话。
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。
只能将支持 java.io.Serializable 接口的对象写入流中。每个 serializable 对象的类都被编码,编码内容包括类名和类签名、对象的字段值和数组值,以及从初始对象中引用的其他所有对象的闭包。
1.概念
序列化:把Java对象转换为字节序列的过程。
反序列化:把字节序列恢复为Java对象的过程。
2.用途
对象的序列化主要有两种用途:
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
3.对象序列化
3.1序列化API
java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。
java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。
3.2代码示例
package serializable; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; import java.util.Date; /*** * 阿里面试 * Java对象的序列化 * @author xiekai * */ public class ObjectSaver { public static void main(String[] args) throws ClassNotFoundException { try { //序列化对象 ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("E:\\work_eclipse\\Serializable\\objectFile.obj")); Customer customer = new Customer("xiekai", 24); out.writeObject("Hello"); out.writeObject(new Date()); out.writeObject(customer); out.close(); //反序列化 ObjectInputStream in = new ObjectInputStream(new FileInputStream("E:\\work_eclipse\\Serializable\\objectFile.obj")); System.out.println("Obj1 " + (String)in.readObject()); System.out.println("Obj2 " + (Date)in.readObject()); Customer obj3 = (Customer) in.readObject(); System.out.println("Obj3 " + obj3); in.close(); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } class Customer implements Serializable { private String name; private int age; public Customer(String name, int age) { super(); this.name = name; this.age = age; } @Override public String toString() { return "Customer [name=" + name + ", age=" + age + "]"; } }
4.说明
读取对象的顺序与写入时的顺序要一致。
对象的默认序列化机制写入的内容是:对象的类,类签名,以及非瞬态和非静态字段的值。
下一篇
http://blog.csdn.net/xkzju2010/article/details/52061451
相关文章推荐
- 拓扑排序及其Java实现
- java静态和动态代理原理
- 深入Java核心 Java内存分配原理精讲
- Spring AOP详细介绍
- spring定时器使用心得
- java_final
- Spring多数据源使用注解事务绑定注意事项和解决办法
- Gradle编译java文件乱码问题
- java_重写与重载的区别
- struts2实现国际化
- java多线程 sleep()和wait()的区别
- Mac OSX 10.10 Yosemite编译OpenJDK 8
- struts2中的action方法的执行顺序
- spring mvc基础学习笔记
- javaweb学习总结(十六)——JSP指令
- ConcurrentHashMap实现原理——Java并发容器
- dubbo异步调用传递性问题的解决方案
- Java中浅复制和深复制
- javaIO(三)
- SpringMVC与Struts2区别与比较总结