当一个对象实现了Serilizable接口,这个对象就可以被序列化,java的这种序列化模式为开发者提供了很多便利,我们可以不必关系具体序列化的过程,只要这个类实现了Serilizable接口,这个的所有属性和方法都会自动序列化。
然而在实际开发过程中,我们常常会遇到这样的问题,这个类的有些属性需要序列化,而其他属性不需要被序列化,诚然,你可以让这个类来实现Externalizable接口,这个接口是Serilizable的子接口,但是你必须实现readExternal和writeExternal方法,你可以在这两个方法中实现具体属性的反序列化和序列化操作。然而这就意味着你必须在这两个方法中手工编写额外的代码来进行具体属性的序列化。java的transient关键字为我们提供了便利,你只需要实现Serilizable接口,将不需要序列化的属性前添加关键字transient,序列化对象的时候,这个属性就不会序列化到指定的目的地中。打个比方,如果一个用户有一些敏感信息(如密码,银行卡号等),为了安全起见,不希望在网络操作(主要涉及到序列化操作,本地序列化缓存也适用)中被传输,这些信息对应的变量就可以加上transient关键字。换句话说,这个字段的生命周期仅存于调用者的内存中而不会写到磁盘里持久化。
1 public class TestTransient { 2 3 /** 4 * @param args 5 * @throws IOException 6 * @throws FileNotFoundException 7 * @throws ClassNotFoundException 8 */ 9 public static void main(String[] args) throws FileNotFoundException, IOException, ClassNotFoundException { 10 A a = new A(25,"张三"); 11 System.out.println(a); 12 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("c://mm.txt")); 13 oos.writeObject(a); 14 oos.close(); 15 ObjectInputStream ois = new ObjectInputStream(new FileInputStream("c://mm.txt")); 16 a = (A)ois.readObject(); 17 System.out.println(a); 18 19 } 20 21 } 22 23 class A implements Serializable{ 24 int a; 25 transient String b; 26 public A(int a,String b){ 27 this.a = a; 28 this.b = b; 29 } 30 public String toString(){ 31 return "a = "+a+",b = "+b; 32 } 33 }
运行结果如下:
a = 25,b = 张三
a = 25,b = null
在上面的例子中,将属性b前添加关键字transient,可以看到虽然序列化的对象a的属性值为“张三”,但是当反序列化之后发现这个属性为空,说明这个属性没有进行序列化。
原文:https://blog.csdn.net/zxl315/article/details/5359151