serilization 序列化 transient 不被序列化

Serizlizable 作用

对于一个存在于Java虚拟机中的对象来说,其内部的状态只保持在内存中。JVM停止之后,这些状态就丢失了。在很多情况下,对象的内部状态是需要被持久化下来的。提到持久化,最直接的做法是保存到文件系统或是数据库之中。比如:对象关系映射(Object-relational mapping)。对象序列化机制(object serialization)是Java语言内建的一种对象持久化方式,可以很容易的在JVM中的活动对象和字节数组(流)之间进行转换。除了可以很简单的实现持久化之外,另外序列化机制的另外一个重要用途是在远程方法调用中,用来对开发人员屏蔽底层实现细节。

 

对于某些类型的对象,其状态是瞬时的,这样的对象是无法保存其状态的。例如一个Thread对象或一个FileInputStream对象 ,对于这些字段,我们必须用transient关键字标明,否则编译器将报措。 

 另外 ,串行化可能涉及将对象存放到 磁盘上或在网络上发达数据,这时候就会产生安全问题。因为数据位于Java运行环境之外,不在Java安全机制的控制之中。对于这些需要保密的字段,不应保存在永久介质中 ,或者不应简单地不加处理地保存下来 ,为了保证安全性。应该在这些字段前加上transient关键字。 

 

 

 

实现Serializable接口的UserInfo类,并且有一个transient关键字修饰的属性

 

 

[java] view plain copy
 
 print?在CODE上查看代码片派生到我的代码片
  1. package com.testtransient.model;  
  2. import java.io.Serializable;  
  3. public class UserInfo implements Serializable {  
  4.    
  5.         private static final long serialVersionUID = 1L;  
  6.    
  7.         private String name ;  
  8.          
  9.         private transient String pwd ;  
  10.          
  11.         public UserInfo(String name,String pwd){  
  12.                this.name =name;  
  13.                this.pwd =pwd;  
  14.        }  
  15.          
  16.         public String toString(){  
  17.                return "name=" +name +",psw=" +pwd ;  
  18.        }  
  19. }  



 

 

通过输入输出流编写的测试程序

 

 

[java] view plain copy
 
 print?在CODE上查看代码片派生到我的代码片
  1. public class TestTransient {  
  2.    
  3.         public static void main(String[] args) {  
  4.               UserInfouserInfo = new UserInfo("张三" , "123456" );  
  5.               System. out.println(userInfo);  
  6.                try {  
  7.                       // 序列化,被设置为transient的属性没有被序列化  
  8.                      ObjectOutputStreamo = new ObjectOutputStream(new FileOutputStream(  
  9.                                    "UserInfo.out"));  
  10.                      o.writeObject(userInfo);  
  11.                      o.close();  
  12.               } catch (Exception e) {  
  13.                      e.printStackTrace();  
  14.               }  
  15.                try {  
  16.                       // 重新读取内容  
  17.                      ObjectInputStream in = new ObjectInputStream( new FileInputStream(  
  18.                                    "UserInfo.out"));  
  19.                      UserInforeadUserInfo = (UserInfo) in.readObject();  
  20.                       // 读取后psw的内容为null  
  21.                      System. out.println(readUserInfo.toString());  
  22.               } catch (Exception e) {  
  23.                      e.printStackTrace();  
  24.               }  
  25.        }  



 

运行结果:

 

 

从上面结果能够看出来经过transient关键字修饰的字段是不能够被序列化的。

posted @ 2016-08-24 14:46  雪飞就飞  阅读(345)  评论(0编辑  收藏  举报