這篇文章將為大家詳細(xì)講解有關(guān)靜態(tài)變量不能序列化的原因,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
我們提供的服務(wù)有:網(wǎng)站設(shè)計、成都做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、富民ssl等。為上1000+企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的富民網(wǎng)站制作公司
靜態(tài)成員屬于類級別的,所以不能序列化,這里的不能序列化的意思,是序列化信息中不包含這個靜態(tài)成員域
這里有一個示例很好的證明了靜態(tài)變量為什么不能序列化:
類Student1
package test; import java.io.Serializable; public class Student1 implements Serializable{ private static final long serialVersionUID = 1L; private String name; private transient String password; private static int count = 0; public Student1(String name,String password){ System.out.println("調(diào)用Student的帶參構(gòu)造方法 "); this.name = name; this.password = password; count++; } public String toString(){ return "人數(shù):" + count + "姓名:" + name + "密碼:" + password; } }
類ObjectSerTest1
package test; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; public class ObjectSerTest1 { public static void main(String args[]){ try{ FileOutputStream fos = new FileOutputStream("test.obj"); ObjectOutputStream oos = new ObjectOutputStream(fos); Student1 s1 = new Student1("張三","123456"); Student1 s2 = new Student1("王五","56"); oos.writeObject(s1); oos.writeObject(s2); oos.close(); FileInputStream fis = new FileInputStream("test.obj"); ObjectInputStream ois = new ObjectInputStream(fis); Student1 s3 = (Student1) ois.readObject(); Student1 s4 = (Student1) ois.readObject(); System.out.println(s3); System.out.println(s4); ois.close(); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e1) { e1.printStackTrace(); } } }
運行結(jié)果:
調(diào)用Student的帶參構(gòu)造方法
調(diào)用Student的帶參構(gòu)造方法
人數(shù):2姓名:張三密碼:null
人數(shù):2姓名:王五密碼:null
類Test1
package test; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; public class Test1{ public static void main(String args[]){ try { FileInputStream fis = new FileInputStream("test.obj"); ObjectInputStream ois = new ObjectInputStream(fis); Student1 s3 = (Student1) ois.readObject(); Student1 s4 = (Student1) ois.readObject(); System.out.println(s3); System.out.println(s4); ois.close(); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e1) { e1.printStackTrace(); } } }
運行結(jié)果:
人數(shù):0姓名:張三密碼:null
人數(shù):0姓名:王五密碼:null
總結(jié):
類ObjectSerTest1 的運行結(jié)果顯示count=2,似乎被序列化了,但是類Test1的運行結(jié)果顯示count=0并未被序列化。
”序列化保存的是對象的狀態(tài),靜態(tài)變量數(shù)以類的狀態(tài),因此序列化并不保存靜態(tài)變量。
這里的不能序列化的意思,是序列化信息中不包含這個靜態(tài)成員域
ObjectSerTest1 測試成功,是因為都在同一個機器(而且是同一個進程),因為這個jvm已經(jīng)把count加載進來了,所以你獲取的是加載好的count,如果你是傳到另一臺機器或者你關(guān)掉程序重寫寫個程序讀入test.obj,此時因為別的機器或新的進程是重新加載count的,所以count信息就是初始時的信息?!?----來自參考網(wǎng)頁
重寫類Test1讀取test.obj顯示的結(jié)果是count的初始時的信息,也驗證了上面一段話。
最后,Java對象的static,transient 修飾的屬性不能被序列化。
關(guān)于靜態(tài)變量不能序列化的原因就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。