1.相互关系
首先两者都是接口,Externalizable继承Serializable,并增加了两个方法声明,分别是writeExternal和readExternal。我画出了UML图来表现他们的关系,如下:
2.Serializable介绍
(1)Serializable接口没有定义方法,也没有任何常量定义,就一空接口。如果有类实现了Serializable接口,则等于告诉JVM此类是可序列化(序列化解释)的。
(2)对于实现了Serializable接口的类,如果需要类的某个成员变量在序列化时被排除,不参与序列化,可在定义成员变量时,使用transient关键词,比如: private transient int a;
(3)serialVersionUID,序列化版本号。 在implements Serializable实现接口时,你可以显示定义serialVersionUID常量,也可以不定义。在不定义的情况下,在编译期间默认会根据类名、方法名、成员变量名等通过一定算法自动生成一个。它是用来识别类的版本的。比如你序列化后,对原本的类作了修改,如果serialVersionUID是你显示定义的,那反序列化还是可以正常进行,因为UID没变。否则,在你修改了类、方法、成员变量名的情况下,自动生成的UID就跟序列化时不一样了,这时候反序列化会失败。通常见到的提示像这样的:
测试代码如下:
package com.wind.DbTec.sqlpkg; 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; /** * Serializable的serialVersionUID的作用,类版本控制 默认UID会根据类名,方法名,属性名自动生成,也可以显示定义 * * @author zhouyanjun * @version 1.0 2014-12-9 */ public class SeriIDTest implements Serializable { /** * */ private static final long serialVersionUID = -8488760619565425801L; //这里显示定义了 int company_id; String company_addr; // int index; public SeriIDTest(int company_id, String company_addr) { this.company_id = company_id; this.company_addr = company_addr; } public String toString() { return "DATA:" + company_id + " " + company_addr; } public void todo() { } // 添加一个无关紧要的方法 public static void main(String[] args) { try { ObjectOutputStream objWriter = new ObjectOutputStream( new FileOutputStream("D://serId.txt")); SeriIDTest seriTest = new SeriIDTest(12, "suzhou"); objWriter.writeObject(seriTest); ObjectInputStream objReader = new ObjectInputStream( new FileInputStream("D://serId.txt")); SeriIDTest seriTest1 = (SeriIDTest) objReader.readObject(); System.out.println(seriTest1); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } } }
3. Externalizable介绍
(1)Externalizable接口提供的writeExternal和readExternal两个方法,给予开发者序列化实现的可控(可以决定哪些字段参与序列化,或者在序列化前后对一些字段值做些修改等)
(2)在实现Externalizable接口时,writeExternal,readExternal两方法的传入参数为ObjectOutputStream和ObjectInputStream,方法内只能调用他们的writeObject和readObject方法,其他方法无法完成序列化;
测试代码如下:
package com.wind.DbTec.sqlpkg; import java.io.Externalizable; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectInputStream; import java.io.ObjectOutput; import java.io.ObjectOutputStream; /** * Externalizable的学习,基于与Serializable的区别 * * @author zhouyanjun * @version 1.0 2014-12-8 */ public class ExternalizableTest implements Externalizable { private String letterstates = "fanruijun"; private int num = 0; public void writeExternal(ObjectOutput out) throws IOException { // TODO Auto-generated method stub out.writeObject(letterstates); out.writeObject(num); //out.writeChar('s'); //不使用writeObject,而使用writeChar } public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { // TODO Auto-generated method stub letterstates = (String) in.readObject(); num = (Integer) in.readObject(); //System.out.println(in.readChar()); //不使用readObject,而使用readChar } public String toString() { return "value:" + letterstates + " " + num; } public static void main(String[] args) { try { ExternalizableTest myTest = new ExternalizableTest(); // 序列化对象写入文件 ObjectOutput out = new ObjectOutputStream(new FileOutputStream( "D://MyTest.txt")); myTest.writeExternal(out); myTest.num = 3; System.out.println(myTest); // 从文件读取 ObjectInput in = new ObjectInputStream(new FileInputStream( "D://MyTest.txt")); myTest.readExternal(in); System.out.println(myTest); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
相关推荐
Java 串行化主要通过实现`java.io.Serializable`接口来实现,同时也提供了`java.io.Externalizable`接口来提供更细粒度的控制。 **一、Serializable接口** `Serializable`是Java中的一个标记接口,没有包含任何方法...
#### 五、`Serializable` 与 `Externalizable` 的区别 除了 `Serializable` 接口之外,Java 还提供了 `Externalizable` 接口来控制序列化过程。`Externalizable` 继承自 `Serializable`,并定义了两个方法: 1. `...
2. **实现Externalizable接口**:这个接口继承自`Serializable`,提供了更高级别的控制,允许开发者自己编写序列化逻辑。 3. **序列化兼容性**:`serialVersionUID`的作用在于保证版本兼容性。开发者可以通过显式...
需要注意的是,只有实现了`Serializable`或`Externalizable`接口的类才能被序列化。`Externalizable`接口允许对象完全控制序列化过程,而仅实现`Serializable`接口的类则采用默认的序列化方式。对于那些不希望被序列...
一种是实现Serializable接口 另一种是实现Externalizable接口 区别: 实现Serializable接口 1 系统自动储存必要的信息 2 Java内建支持,易于实现,只需实现该接口即可,无须任何代码支持 3 性能略差 实现...
Serializable有一个子接口Externalizable,实现Externalizable接口的类可以自行控制对象序列化荷反序列化过程。 一般来说,没有必要自己实现序列化接口,直接交给Java虚拟机是上策。 实现了序列化接口的类,如果...
### 对象的序列化与反序列化 #### 概述 序列化与反序列化是计算机科学领域中一种重要的...通过以上介绍,我们可以了解到对象序列化与反序列化的基本原理以及不同接口实现的区别,这对于理解和应用这项技术至关重要。
- **`Externalizable`接口**:这是`Serializable`接口的一个子接口,它要求实现类提供两个方法`readExternal`和`writeExternal`来自定义序列化和反序列化的过程。 #### 二、序列化的具体实现方式 在Java中,对象...
总结来说,Java中的序列化和反序列化是通过`Serializable`接口和`Externalizable`接口来实现的。`Serializable`接口是默认的序列化方式,适用于大多数简单情况;而`Externalizable`接口则提供了自定义序列化行为的...
Java 提供了两种方式来实现序列化:一种是使用 Serializable 接口,另一种是使用 Externalizable 接口。 在上面的代码中,我们可以看到, ByteToObject 方法将 byte 数组转化为对象,而 ObjectToByte 方法将对象...
- 序列化机制通过 Externalizable 或 Serializable 接口实现。 11. 在 Java 中不可变对象(Immutable Objects): - 一旦被创建,状态不能改变。 - 优点是线程安全。 - 示例:String、Integer。 12. Java 中的...
要实现对象序列化,Java类必须实现`Serializable`接口或`Externalizable`接口。`Serializable`接口是一个空接口,当一个类实现它时,表明该类的所有实例都可以被序列化。而`Externalizable`接口提供了更多的控制权,...
1)Serializable和Externalizable接口Xstream框架2)Simple框架 3)Apache的AXIOM框架 2、XML验证文档的生成工具 trang.jar 3、利用XSD文件的XML3种验证方法 1)Dom4j的SAXValidator (dom4j.jar, javax.xml....
在了解标题和描述中提及的知识点之前,我们需要先梳理一下文档的主要内容和上下文。文档标题《伤口撕开,给你看.pdf》和描述“开年的第二天 序列化,又见序列化 好了,伤口基本愈合了。你要不要来撒盐”暗示了这篇...
Externalizable 继承了 Serializable,多了两个方法:writeExternal 和 readExternal,用来控制需要序列化哪些字段。 实现方法 下面是一个简单的示例代码,演示如何实现 Serializable 和 Externalizable 接口: `...