Java中transient關(guān)鍵字有什么用-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)Java中transient關(guān)鍵字有什么用,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

專(zhuān)注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)藍(lán)山免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

百度百科的解釋?zhuān)?/strong>

Java語(yǔ)言的關(guān)鍵字,變量修飾符,如果用transient聲明一個(gè)實(shí)例變量,當(dāng)對(duì)象存儲(chǔ)時(shí),它的值不需要維持。換句話來(lái)說(shuō)就是,用transient關(guān)鍵字標(biāo)記的成員變量不參與序列化過(guò)程。

作用:Java的serialization提供了一種持久化對(duì)象實(shí)例的機(jī)制。當(dāng)持久化對(duì)象時(shí),可能有一個(gè)特殊的對(duì)象數(shù)據(jù)成員,我們不想用serialization機(jī)制來(lái)保存它。為了在一個(gè)特定對(duì)象的一個(gè)域上關(guān)閉serialization,可以在這個(gè)域前加上關(guān)鍵字transient。當(dāng)一個(gè)對(duì)象被序列化的時(shí)候,transient型變量的值不包括在序列化的表示中,然而非transient型的變量是被包括進(jìn)去的。

編碼試驗(yàn)加以證明:

1.自定義類(lèi)(為了方便,我直接在main方法所在類(lèi)中添加的一個(gè)靜態(tài)屬性類(lèi),或者叫成員類(lèi)

public static class TransientTest implements Serializable{private static final long serialVersionUID = 233858934995755239L;private String name1;private transient String name2;public TransientTest(String name1,String name2){this.name1 = name1;this.name2 = name2;}public String toString(){return String.format("TransientTest.toString(): name1=%s,name2=%s", name1,name2);}}

2.寫(xiě)一個(gè)測(cè)試方法

public static void testTransient(){String name1="常規(guī)屬性",name2="transient修飾的屬性";TransientTest test = new TransientTest(name1, name2);System.out.println("序列化前:"+test.toString());ObjectOutputStream outStream;ObjectInputStream inStream;String filePath = "D:/test/object/TransientTest.obj";try {outStream = new ObjectOutputStream(new FileOutputStream(filePath));outStream.writeObject(test);inStream = new ObjectInputStream(new FileInputStream(filePath));TransientTest readObject = (TransientTest)inStream.readObject();System.out.println("序列化后:"+readObject.toString());} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (ClassNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();}}

3.在main方法中執(zhí)行,然后可以看到得到的結(jié)果為

印證了上面所講的“用transient關(guān)鍵字標(biāo)記的成員變量不參與序列化過(guò)程”。

用二進(jìn)制查看器打開(kāi)這個(gè)文件也可以看到,數(shù)據(jù)中只有name1,沒(méi)有name2。(請(qǐng)忽略亂碼問(wèn)題,這個(gè)不是重點(diǎn)哈。)

延伸:

在查看JDK源碼的時(shí)候會(huì)發(fā)現(xiàn)很多地方都會(huì)加上transient關(guān)鍵字來(lái)修飾一些屬性,那究竟是出于什么考慮才這么做呢?

我覺(jué)得,應(yīng)該是為了節(jié)約磁盤(pán)空間,避免造成不必要的浪費(fèi)吧。

以ArrayList中的 transient Object[] elementData 為例,這個(gè)成員變量的注釋為:

翻譯出來(lái)就是:

/ * **存儲(chǔ)ArrayList元素的數(shù)組緩沖區(qū)。* ArrayList的容量是這個(gè)數(shù)組緩沖區(qū)的長(zhǎng)度。任何*帶有elementData的空ArrayList == DEFAULTCAPACITY_EMPTY_ELEMENTDATA*當(dāng)添加第一個(gè)元素時(shí),將被擴(kuò)展到DEFAULT_CAPACITY。* /

這個(gè)緩沖區(qū)的容量實(shí)際上并不是ArrayList的容量,因?yàn)槠鋵?shí)際上會(huì)預(yù)留一些空間,當(dāng)空間不足時(shí)還會(huì)擴(kuò)容,為減少浪費(fèi),因此在序列化時(shí)不會(huì)按照默認(rèn)算法將這個(gè)成員變量寫(xiě)入磁盤(pán)。而是寫(xiě)了個(gè)writeObject方法,序列化時(shí)會(huì)調(diào)用這個(gè)方法將其持久化,在反序列化是,調(diào)用readObject,將其恢復(fù)出來(lái)。

這2個(gè)方法為:

參考ArrayList,在上面的TransientTest中添加2個(gè)方法,見(jiàn)代碼:

public static class TransientTest implements Serializable{private static final long serialVersionUID = 233858934995755239L;private String name1;private transient String name2;public TransientTest(String name1,String name2){this.name1 = name1;this.name2 = name2;}public String toString(){return String.format("TransientTest.toString(): name1=%s,name2=%s", name1,name2);} private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOException {s.defaultWriteObject();s.writeObject(name2);}private void readObject(java.io.ObjectInputStream s) throws java.io.IOException, ClassNotFoundException {s.defaultReadObject();name2=String.valueOf(s.readObject());}}

關(guān)于Java中transient關(guān)鍵字有什么用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

網(wǎng)站名稱(chēng):Java中transient關(guān)鍵字有什么用-創(chuàng)新互聯(lián)
本文鏈接:http://muchs.cn/article18/spigp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、定制網(wǎng)站、標(biāo)簽優(yōu)化品牌網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)