Java序列化
序列化
Java中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据、有关对象的类型信息和存储在对象中数据的类型。
反序列化
将序列化对象写入文件之后,可以从文件中读取出来,并且对它进行反序列化,也就是说,对象的类型信息、对象的数据,还有对象中的数据类型可以用来在内存中新建对象。
序列化应用
- 要将内存中的对象保存到硬盘上,过段时间再读取到内存中,这时候该对象就需要实现Serializable接口;
- Socket编程的时候,可能需要传输对象,该对象也需要实现Serializable接口。最常见的是传输字符串,String也实现了Serializable接口;
- 通过RMI远程调用接口,传输对象也要实现Serializable接口;
代码片
如下.
// Employee.java
public class Employee implements java.io.Serializable
{
public String name;
public String address;
public transient int SSN;
public int number;
public void mailCheck()
{
System.out.println("Mailing a check to " + name
+ " " + address);
}
}
//序列化
//SerializeDemo.java
import java.io.*;
public class SerializeDemo
{
public static void main(String [] args)
{
Employee e = new Employee();
e.name = "Reyan Ali";
e.address = "Phokka Kuan, Ambehta Peer";
e.SSN = 11122333;
e.number = 101;
try
{
FileOutputStream fileOut =
new FileOutputStream("/tmp/employee.ser");
ObjectOutputStream out = new ObjectOutputStream(fileOut);
out.writeObject(e);
out.close();
fileOut.close();
System.out.printf("Serialized data is saved in /tmp/employee.ser");
}catch(IOException i)
{
i.printStackTrace();
}
}
}
//反序列化
//DeserializeDemo.java
import java.io.*;
public class DeserializeDemo
{
public static void main(String [] args)
{
Employee e = null;
try
{
FileInputStream fileIn = new FileInputStream("/tmp/employee.ser");
ObjectInputStream in = new ObjectInputStream(fileIn);
e = (Employee) in.readObject();
in.close();
fileIn.close();
}catch(IOException i)
{
i.printStackTrace();
return;
}catch(ClassNotFoundException c)
{
System.out.println("Employee class not found");
c.printStackTrace();
return;
}
System.out.println("Deserialized Employee...");
System.out.println("Name: " + e.name);
System.out.println("Address: " + e.address);
System.out.println("SSN: " + e.SSN);
System.out.println("Number: " + e.number);
}
}
本文转载自
https://my.oschina.net/hosee/blog/412431
http://www.runoob.com/java/java-serialization.html