JAVA對象序列化機制一般來(lái)講有兩種用途:
1.需要將對象的狀態(tài)保存到文件中,而后能夠通過(guò)讀入對象狀態(tài)來(lái)重新構造對象,恢復程序狀態(tài)
2.使用套接字在網(wǎng)絡(luò )上傳送對象的程序來(lái)說(shuō),是很有用的。
我們通過(guò)讓類(lèi)實(shí)現java.io.Serializable 接口可以將類(lèi)序列化。這個(gè)接口是一個(gè)制造者(marker)接口。也就是說(shuō),對于要實(shí)現它的類(lèi)來(lái)說(shuō),該接口不需要實(shí)現任何方法。它主要用來(lái)通知Java虛擬機(JVM),需要將一個(gè)對象序列化。
對于這個(gè),有幾點(diǎn)我們需要明確:
1.并非所有類(lèi)都可以序列化,在cmd下,我們輸入serialver java.net.socket,可以得到socket是否可序列化的信息,實(shí)際上socket是不可序列化的。
2.java有很多基礎類(lèi)已經(jīng)實(shí)現了serializable接口,比如string,vector等。但是比如hashtable就沒(méi)有實(shí)現serializable接口。
將對象讀出或者寫(xiě)入流的主要類(lèi)有兩個(gè): ObjectOutputStream與ObjectInputStream 。ObjectOutputStream 提供用來(lái)將對象寫(xiě)入輸出流的writeObject方法, ObjectInputStream提供從輸入流中讀出對象的readObject方法。使用這些方法的對象必須已經(jīng)被序列化的。也就是說(shuō),必須已經(jīng)實(shí)現 Serializable接口。如果你想writeobject一個(gè)hashtable對象,那么,會(huì )得到一個(gè)異常。
下面舉個(gè)例子:
import java.io.*;
public class testser implements Serializable {
public int ii;
testser()
{
}
testser( int param )
{
ii = param;
}
}
testser是一個(gè)實(shí)現了serializable接口的類(lèi)。
讀寫(xiě)這個(gè)序列化過(guò)的類(lèi):
import java.io.*;
public class Ser {
private static String datafile="ser.data";
public static void main( String[] argv )
{
System.out.println( "Java Serialization Demo." );
testser data;
try {
ObjectInputStream in = new ObjectInputStream( new FileInputStream( datafile ));
data = (testser) in.readObject();
in.close();
}
catch (Exception e) {
data = new testser();
}
System.out.println( "Original data: ii = " + data.ii );
data.ii++;
try {
ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream( datafile ) );
out.writeObject( data );
out.flush();
out.close();
}
catch (Exception e) {
System.out.println( e );
}
}
}
還有可以通過(guò)套接字傳遞序列化對象,大概類(lèi)似。
看到這里或許很多人都會(huì )有個(gè)疑問(wèn),是否所有的對象都可以序列化呢?
當然是不可以的了,至于為什么不可以,那就有很多原因了,比如:
1.安全方面的原因,比如一個(gè)對象擁有private,public等f(wàn)ield,對于一個(gè)
要傳輸的對象,比如寫(xiě)到文件,或者進(jìn)行rmi傳輸等等,在序列化進(jìn)行傳輸的
過(guò)程中,這個(gè)對象的private等域是不受保護的.
2.資源分配方面的原因,比如socket,thread類(lèi),如果可以序列化,進(jìn)行傳輸
或者保存,也無(wú)法對他們進(jìn)行重新的資源分配,而且,也是沒(méi)有必要這樣實(shí)現.
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1555485