欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java中的Serializable、transient關鍵字詳解

 更新時間:2023年09月28日 10:35:42   作者:BeanInJ  
這篇文章主要介紹了java中的Serializable、transient關鍵字詳解,序列化只會保存屬性值,不會保存方法,通過反序列化可以把序列化后的內(nèi)容恢復成對象,需要的朋友可以參考下

1、Serializable 序列化接口

如下,寫一個類實現(xiàn)Serializable,并標注序列化版本號

public class  Foo implements Serializable  { 
	private static final long serialVersionUID = -5809782578272943999L;
	private int id;
	private String name;
	.
	.
	.
}

實現(xiàn)序列化接口Serializable有什么用?

1.1、有什么用?

沒有實現(xiàn)序列化的對象都保存在堆(Heap)中。 實現(xiàn)序列化后可以保存到一個文件里。

如下例:

// class  Foo implements Serializable
Foo foo = new Foo();
foo.setId(1);  
foo.setName("ho"); 
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("foo.ser"));
oos.writeObject(student);
oos.flush();
oos.close();

foo實例化后被保存在foo.ser文件中

foo.ser

Foo [id=1, name=ho]

1.2、什么情況下用?

1、該對象數(shù)據(jù)需要寫入數(shù)據(jù)庫

2、該對象需要通過網(wǎng)絡、RMI、緩存等傳遞或保存

3、該對象需要在jvm與jvm間交流

1.3、要注意些什么

1、序列化只會保存屬性值,不會保存方法

2、通過反序列化可以把序列化后的內(nèi)容恢復成對象

3、聲明為 static 和 transient 的成員變量,不能被序列化,static 成員變量是描述類級別的屬性,transient 表示臨時數(shù)據(jù)。

4、某個類可以被序列化,則其子類也可以被序列化

5、反序列化讀取序列化對象的順序要保持一致

2、transient 關鍵字

如下是LinkedList的部分源碼

public class LinkedList<E>
    extends AbstractSequentialList<E>
    implements List<E>, Deque<E>, Cloneable, java.io.Serializable
{
    transient int size = 0;
    transient Node<E> first;
    .
    .
    .
 }

我們能看到size、first兩個屬性前面加了transient關鍵字。 transient 關鍵字,主要用來忽略我們不希望進行序列化的變量。

2.1、什么情況下用?

首先,當一個類需要序列化,但是某個屬性不需要被序列化就可以加此關鍵字。 都有哪些場景呢?

1、一些敏感信息,如密碼、銀行卡號等

2、非必要信息,如LinkedList中的大小、位置等

2.2、要注意些什么

1、需要實現(xiàn)Serializable接口。

2、transient關鍵字只能修飾變量,而不能修飾方法和類。

3、本地變量是不能被transient關鍵字修飾的

4、實現(xiàn)Externalizable接口,需要在writeExternal方法中進行手工指定所要序列化的變量,這與是否被transient修飾無關。

3、序列化與反序列化

ObjectOutputStream:IO 類,包含序列化對象的方法,writeObject()

ObjectInputStream:IO 類,包含反序列化對象的方法,readObject()

序列化示例:

public static void main(String[] args) throws Exception {
    //  創(chuàng)建 Java 對象(Foo必須已經(jīng)實現(xiàn)了Serializable接口)
    Foo foo = new Foo(22,"tt");
    //  對象輸出流
    ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("foo"));
    // 使用 writeObject 序列化對象
    oos.writeObject(student);
    // 刷新
    oos.flush();
    //  關閉流
    oos.close();
}

反序列化示例:

public static void main(String[] args) throws Exception {
    //  對象輸入流
    ObjectInputStream ois = new ObjectInputStream(new FileInputStream("foo"));
    //  使用 readObject() 反序列化  
    Object obj = ois.readObject();
    //  使用對象
    System.out.println(obj);
    //  關閉流
    ois.close();
}

反序列化需要借助文件輸入流讀取指定路徑的二進制文件。

3.1、serialVersionUID 版本號的作用

JVM 首先會通過類名來區(qū)分 Java 類,類名不同,則不是同一個類。當類名相同時,JVM 就會通過序列化版本號來區(qū)分 Java 類,如果序列化版本號相同就為同一個類,序列化版本號不同就為不同的類。

到此這篇關于java中的Serializable、transient關鍵字詳解的文章就介紹到這了,更多相關java的Serializable、transient內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論