java对象序列化java.io.Serializable 接口实践

简介:

java.io.Serializable 接口没有任何方法和字段,仅仅表示实现它的类的对象可以被序列化。实现了这个接口的所有类及其子类都可以对象序列化。 
序列化前,虚拟机要清楚每个对象的结构,所以序列化会比较慢,如果关心性能或者需要读取大量的特定的类对象,可以使用 java.io.Externalizable接口 
对象序列化一般出现在如下的环境下: 
把对象的字节序列保存在物理存储介质中(如硬盘文件); 
把对象的字节序列经网络传输给请求者; 

序列过程的特殊处理: 
private void writeObject(java.io.ObjectOutputStream out)     throws IOException private void readObject(java.io.ObjectInputStream in)  throws IOException, ClassNotFoundException; 
当ObjectOutputStream对一个对象开始序列化/反序列化时,如果该对象类具有了方法writeObject()/readObject(),就执行该方法,否则执行默认方法defaultWriteObject()/defaultReadObject(). 
ANY-ACCESS-MODIFIER Object writeReplace() throws ObjectStreamException;ANY-ACCESS-MODIFIER Object readResolve() throws ObjectStreamException; 
在做序列化前,用另一个可序列化对象替代该序列化对象,然后进行序列化(调用defaultWriteObject()或者 
writeObject())方法完成序列化操作。 

不序列化的状态: 
对对象的静态的或瞬时的(transient)成员,不会进行序列化。 

serialVersionUID 版本号: 
序列化serialVersionUID 的版本号在反序列化时,用于标志序列化的发送者和接受者是否为该对象加载了与序列化是相兼容的类,如果不兼容(serialVersionUID 不相同),会导致InvalidClassException 。如果类没有显示的声明serialVersionUID,序列化是会计算默认的值。默认值在不同编译器中的结果肯能不同,为了能更好的跨平台,最好显示的声明它。 
ANY-ACCESS-MODIFIER static final long serialVersionUID = 42L; 

实例练习: 
Java代码 

public  class SerialTest {               public  static  void main(String[] args){           Customers customer =  new Customers();            try {               FileOutputStream file =  new FileOutputStream( "customer.obj");               ObjectOutputStream out =  new ObjectOutputStream(file);               out.writeObject(customer);                              System.out.println(file.getFD().toString());               file.close();               out.close();                              FileInputStream fileIN =  new FileInputStream( "customer.obj");               ObjectInputStream in =  new ObjectInputStream(fileIN);                try {                   Customers cus = (Customers)in.readObject();   /*这里虽然可以打印出静态变量,但不是因为对它进行了序列化,而是因为静态变量自身的特性造成的*/                   System.out.println(cus.toString());               }  catch (ClassNotFoundException e) {                   e.printStackTrace();               }           }  catch (FileNotFoundException e) {               e.printStackTrace();           }  catch (IOException e) {               e.printStackTrace();           }       }   }      class Customers  implements Serializable{        private  static  final  long serialVersionUID = 167L;               private String name =  "aq";        private  int old =  45;        private String address =  "SuZhou JiangSu China";        private  transient String alias =  "aaq";        private  static String alisa1 =  "aaaq";               private  void writeObject(ObjectOutputStream out) throws IOException{                  this.old =  55;           out.defaultWriteObject();       }               private  void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException{           in.defaultReadObject();            this.old =  this.old +  5;               }               public String toString(){           StringBuilder builder =  new StringBuilder( 128);           builder.append( "\r\\r\\r\\r\nalisa1=").append(alisa1);            return builder.toString();       } }

本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2010/12/20/1911925.html,如需转载请自行联系原作者
目录
相关文章
|
10天前
|
Java 数据挖掘
java实践
【4月更文挑战第9天】java实践
12 1
|
1天前
|
Java
Java接口中可以定义哪些方法?
【4月更文挑战第13天】
4 0
Java接口中可以定义哪些方法?
|
1天前
|
Java
Java中如何克隆一个对象?
【4月更文挑战第13天】
8 0
|
1天前
|
安全 Java 程序员
Java中的多线程并发编程实践
【4月更文挑战第18天】在现代软件开发中,为了提高程序性能和响应速度,经常需要利用多线程技术来实现并发执行。本文将深入探讨Java语言中的多线程机制,包括线程的创建、启动、同步以及线程池的使用等关键技术点。我们将通过具体代码实例,分析多线程编程的优势与挑战,并提出一系列优化策略来确保多线程环境下的程序稳定性和性能。
|
2天前
|
负载均衡 Java 开发者
细解微服务架构实践:如何使用Spring Cloud进行Java微服务治理
【4月更文挑战第17天】Spring Cloud是Java微服务治理的首选框架,整合了Eureka(服务发现)、Ribbon(客户端负载均衡)、Hystrix(熔断器)、Zuul(API网关)和Config Server(配置中心)。通过Eureka实现服务注册与发现,Ribbon提供负载均衡,Hystrix实现熔断保护,Zuul作为API网关,Config Server集中管理配置。理解并运用Spring Cloud进行微服务治理是现代Java开发者的关键技能。
|
2天前
|
Java API 数据库
深研Java异步编程:CompletableFuture与反应式编程范式的融合实践
【4月更文挑战第17天】本文探讨了Java中的CompletableFuture和反应式编程在提升异步编程体验上的作用。CompletableFuture作为Java 8引入的Future扩展,提供了一套流畅的链式API,简化异步操作,如示例所示的非阻塞数据库查询。反应式编程则关注数据流和变化传播,通过Reactor等框架实现高度响应的异步处理。两者结合,如将CompletableFuture转换为Mono或Flux,可以兼顾灵活性和资源管理,适应现代高并发环境的需求。开发者可按需选择和整合这两种技术,优化系统性能和响应能力。
|
2天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
2天前
|
Java API 数据库
深入解析:使用JPA进行Java对象关系映射的实践与应用
【4月更文挑战第17天】Java Persistence API (JPA) 是Java EE中的ORM规范,简化数据库操作,让开发者以面向对象方式处理数据,提高效率和代码可读性。它定义了Java对象与数据库表的映射,通过@Entity等注解标记实体类,如User类映射到users表。JPA提供持久化上下文和EntityManager,管理对象生命周期,支持Criteria API和JPQL进行数据库查询。同时,JPA包含事务管理功能,保证数据一致性。使用JPA能降低开发复杂性,但需根据项目需求灵活应用,结合框架如Spring Data JPA,进一步提升开发便捷性。
|
3天前
|
设计模式 Java
Java接口与抽象类
Java接口与抽象类
15 0
|
6天前
|
存储 Java
Java输入输出:解释一下序列化和反序列化。
Java中的序列化和反序列化是将对象转换为字节流和反之的过程。ObjectOutputStream用于序列化,ObjectInputStream则用于反序列化。示例展示了如何创建一个实现Serializable接口的Person类,并将其序列化到文件,然后从文件反序列化回Person对象。
15 5