当两个进程在进行远程通信时,无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送,称为对象的序列化;接收方则需要把字节序列再恢复为Java对象,称为对象的反序列化。 只有实现了Serializable和Externalizable接口的类的对象才能被序列化,而Externalizable接口又继承自Serializable接口。下面是序列化和外部化接口代码:
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
SerializableMyTest
1
package serializableTest;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import java.io.FileInputStream;
4
import java.io.FileOutputStream;
5
import java.io.ObjectInputStream;
6
import java.io.ObjectOutputStream;
7
import java.io.Serializable;
8
import java.util.Date;
9data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
10data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class SerializableMyTest
{
11data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
12data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String[] args) throws Exception
{
13
// TODO Auto-generated method stub
14
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(
15
"shit.obj"));
16
Customer customer = new Customer("Gefforey", 23);
17
out.writeObject("Hello,gefforey");
18
out.writeObject(new Date());
19
out.writeObject(customer);
20
out.writeInt(520);
21
out.close();
22data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
23
System.out.println();
24
ObjectInputStream in = new ObjectInputStream(new FileInputStream(
25
"shit.obj"));
26
System.out.println("obj1=" + (String) in.readObject());
27
System.out.println("obj2=" + (Date) in.readObject());
28
System.out.println("obj3:" + (Customer) in.readObject());
29
System.out.println("obj4=" + in.readInt());
30
in.close();
31
}
32
}
33data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
34data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
class Customer implements Serializable
{
35
public String name;
36data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
37
public int age;
38data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
39data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Customer(String name, int age)
{
40
this.name = name;
41
this.age = age;
42
}
43data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String toString()
{
45
return "name=" + name + ",age=" + age + ".";
46
}
47
}
48data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
obj1=Hello,gefforey
obj2=Sat Jun 20 17:32:20 CST 2009
obj3:name=Gefforey,age=23.
obj4=520
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
AppTest
1
package serializableTest;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import java.io.Externalizable;
4
import java.io.FileInputStream;
5
import java.io.FileOutputStream;
6
import java.io.IOException;
7
import java.io.ObjectInput;
8
import java.io.ObjectInputStream;
9
import java.io.ObjectOutput;
10
import java.io.ObjectOutputStream;
11
import java.io.Serializable;
12data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
13data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
14
//必须得实现Serializable接口
15
//writing aborted; java.io.NotSerializableException: serializableTest.Customer2
16data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
class Customer2 implements Serializable
{
17
public String name;
18data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
19
public int age;
20data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
21
@Override
22data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int hashCode()
{
23
final int PRIME = 31;
24
int result = 1;
25
result = PRIME * result + age;
26
result = PRIME * result + ((name == null) ? 0 : name.hashCode());
27
return result;
28
}
29data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
30
@Override
31data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean equals(Object obj)
{
32
if (this == obj)
33
return true;
34
if (obj == null)
35
return false;
36
if (getClass() != obj.getClass())
37
return false;
38
final Customer2 other = (Customer2) obj;
39
if (age != other.age)
40
return false;
41data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (name == null)
{
42
if (other.name != null)
43
return false;
44
} else if (!name.equals(other.name))
45
return false;
46
return true;
47
}
48data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
49data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Customer2(String name, int age)
{
50
this.name = name;
51
this.age = age;
52
}
53data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
54data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String toString()
{
55
return "name=" + name + ",age=" + age + ".";
56
}
57
}
58data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
59data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
60data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/**//*
61
* 相当于要序列化得类
62
*/
63data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
class Customer3 implements Externalizable
{ // Test类必须实现Externalizable接口
64
private String letterstates = "gefforey";
65data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
66
private int num = 0;
67
68
//要序列化得类中还可以加需要序列化的类,Customer2也要实现Serilizable接口
69
private Customer2 cus =new Customer2("ffffffffff",24);
70data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
71data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Customer3()
{
72
}
73data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
74data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void writeExternal(ObjectOutput out) throws IOException
{
75
out.writeObject(letterstates);
76
out.write(88); // 在序列化的数据最后加个88
77
out.writeObject(cus);
78
System.out.println("in writeExternal---"+cus.hashCode());
79
}
80data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
81
public void readExternal(ObjectInput in) throws IOException,
82data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
ClassNotFoundException
{
83
letterstates = (String) in.readObject();
84
num = in.read(); // 把数字88加进来
85
Customer2 cusTemp = (Customer2) in.readObject();
86
System.out.println("cus==cusTemp---"+(cus==cusTemp));
87
System.out.println("in readExternal---"+cus.hashCode());
88
89
}
90data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
91data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void printOut()
{ // 测试
92
System.out.println(letterstates +"--"+num);
93
}
94
}
95data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
96data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class AppTest
{
97data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void saveGame()
{
98
Customer3 m = new Customer3();
99data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (m != null)
{
100data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
101
FileOutputStream ostream = new FileOutputStream("t.txt");
102
ObjectOutputStream p = new ObjectOutputStream(ostream);
103data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
104
p.writeObject(m); // writeExternal()自动执行
105data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
106
p.flush();
107
ostream.close();
108data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (IOException ioe)
{
109
System.out.println("Error saving file:");
110
System.out.println(ioe.getMessage());
111
}
112
}
113
}
114data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
115data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
private void loadGame()
{
116data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
117
FileInputStream instream = new FileInputStream("t.txt");
118
ObjectInputStream p = new ObjectInputStream(instream);
119
Customer3 m = (Customer3) p.readObject();// readExternal()自动执行
120
m.printOut();
121
instream.close();
122data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
} catch (Exception e)
{
123
System.out.println("Error loading file:");
124
System.out.println(e.getMessage());
125
}
126
}
127data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
128data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String[] args)
{
129
new AppTest().saveGame();
130
new AppTest().loadGame();
131
}
132
}
133data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
in writeExternal----1524332777
cus==cusTemp---false
in readExternal----1524332777
gefforey--88
序列化会自动存储必要的信息,用以反序列化被存储的实例,而外部化则只保存被存储的类的标识。当你通过java.io.Serializable接口序列化一个对象时,有关类的信息,比如它的属性和这些属性的类型,都与实例数据一起被存储起来。在选择走Externalizable这条路时,Java 只存储有关每个被存储类型的非常少的信息。
每个接口的优点和缺点
Serializable接口
· 优点:内建支持
· 优点:易于实现
· 缺点:占用空间过大
· 缺点:由于额外的开销导致速度变比较慢
Externalizable接口
· 优点:开销较少(程序员决定存储什么)
· 优点:可能的速度提升
· 缺点:虚拟机不提供任何帮助,也就是说所有的工作都落到了开发人员的肩上。
在两者之间如何选择要根据应用程序的需求来定。Serializable通常是最简单的解决方案,但是它可能会导致出现不可接受的性能问题或空间问题;在出现这些问题的情况下,Externalizable可能是一条可行之路。
posted on 2009-06-20 17:43
Frank_Fang 阅读(484)
评论(1) 编辑 收藏 所属分类:
Java编程