序列化Externalizable

原创 2016年06月01日 16:06:05
Person.java
package main;

import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.text.SimpleDateFormat;
import java.util.Date;

/**@author 		    ctl
 *  @date    		2016-6-1下午3:00:21
 *  @package_name main
 *  @project_name   Spring3.0企业应用开发实战
 *  @version 		version.1.0
 */
public class Person implements Externalizable{
	private String id;
	private String name;
	

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	//当序列化对象时,该方法自动调用   
    public void writeExternal(ObjectOutput out) throws IOException{   
        System.out.println("现在执行序列化方法");   
        //可以在序列化时写非自身的变量   
        Date date=new Date();   
        out.writeObject(date);   
        //只序列化userName,userPass变量   
        out.writeObject(name);   
        out.writeObject(id);   
    }   

    //当反序列化对象时,该方法自动调用   
    public void readExternal(ObjectInput in) throws IOException,ClassNotFoundException{   
        System.out.println("现在执行反序列化方法");   
        Date date=(Date)in.readObject();   
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
        System.out.println("序列化时间:"+sdf.format(date));
        this.name="name:"+(String)in.readObject();   
        this.id="id:"+(String)in.readObject();   
    }

	public String toString() {
		return "Person [id=" + id + ", name=" + name + "]";
	}
}

	Person per=new Person();
		per.setId(UUID.randomUUID().toString());
		per.setName("ctl");
		File file=new File("D:\\person.obj");
		ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream(file));
		oos.writeObject(new Date());
		oos.writeObject(per);
		oos.close();
		
		ObjectInputStream ois=new ObjectInputStream(new FileInputStream(file));
		SimpleDateFormat sdf=new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
		System.out.println(sdf.format(ois.readObject()));
		System.out.println(ois.readObject());
		ois.close();

相关文章推荐

JAVA序列化基础知识Serializable与Externalizable的区别

大家都知道Serializable是一个mark interface,告诉JVM这个对象可以被转换成二进制流来传输. 但是Serializable与Externalizable的转换二进制流的...

序列化Serializable和Externalizable

序列化就是将一个对象(标志对象的类型)及其状态转换为字节码,以文件,内存,数据库等形式保存起来。反序列化就是在适当的时候通过读取这些文件,得到原有状态的对象。 序列化可以通过实现两种接口来实现,即S...

java Externalizable序列化接口

Externalizable序列化接口和Serializable序列化不同,Seriazible序列化由系统自动实现细节,默认会将对象的所有成员变量序列化(除非是用transient关键字修饰),而E...

[疯狂Java]I/O:其它自定义序列化的方法(transient、writeReplace、readResolve、Externalizable)

1. 一种不是很好的排除序列化——transient关键字:     1) 如果你不想让对象中的某个成员被序列化可以在定义它的时候加上transient关键字进行修饰,例如: class A impl...

话说JAVA SE 序列化(serializable)与 外部化(externalizable)简单实例

import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.ObjectInputStream; i...

JAVA 对象序列化(二)——Externalizable

在Java对象序列化(一)——Serializable一文中我们可以看到,Java默认的序列化机制非常简单,而且序列化后的对象不需要再次调用构造器重新生成,但是在实际中,我们可以会希望对象的某一部分不...
  • djun100
  • djun100
  • 2014年01月11日 17:48
  • 759

Java 序列化简单理解,serializable与externalizable区别?

什么是对象序列化? 把Java对象状态保存为一组字节(序列化),之后还可以把这些字节组装成对象(反序列化)。   为什么要使用对象序列化? 1. 使用RMI(远程方法调用) 2. 网络中传递对象(Ja...

对象的序列化实现Serializable 接口和Externalizable接口

/** 对象的序列化: **/ import java.io.*; class Animal implements Serializable //实现Serializable 的接口 {...

Java—序列化—Serializable—Externalizable

众所周知,java支持对对象的序列化操作。 为什么要序列化对象呢? 总结起来也就一句话,对一个对象的持久化。也就是说该对象可以以某种形式保存起来,以便我在需要的时候对其反序列化操作后可以还原回来。 ...

java序列化java.io.Externalizable

原博客地址: http://wxg6203.iteye.com/blog/642598 这次我们讲的是控制对象的序列化和反序列化  控制序列化就是有选择的序列化对象,而不是把对象的所以内容...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:序列化Externalizable
举报原因:
原因补充:

(最多只允许输入30个字)