日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java 变量序列化_Java序列化与静态变量

發布時間:2025/3/15 java 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java 变量序列化_Java序列化与静态变量 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

簡介:

Java序列化,就是指將一個對象轉化為二進制的byte流(注意,不是bit流),然后以文件的方式進行保存。

序列化操作:將對象保存至文件;

反序列化操作:從文件恢復出對象;

配置:

對象如果要序列化,則必須集成Serializable接口;

在實現序列化時,用ObjectOutputStream實現;

而反序列化時,用ObjectInputStream實現;

方法:

1. 序列化:

(1) public ObjectOutputStream(OutputStream out) throws IOException

(2) public final void writeObject(Object obj)

(3) public void close() throws IOException

2.反序列化:

(1) public ObjectInputStream(InputStream in) throws IOException

(2) public final void readObject(Object obj)

(3) public void close() throws IOException

注意:

Java序列化是不能序列化static變量的,因為其保存的是對象的狀態,而static變量保存在全局數據區,在對象未實例化時就已經生成,屬于類的狀態。

為了方便理解,我們舉例說明:

例子:

首先附上我們要序列化的對象的生成類:

package test;

import java.io.Serializable;

public class Person implements Serializable{

/**

*

*/

private static final long serialVersionUID = 1L;

private String name;

private int age;

public static String test="IBM";

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

}這里我們有static變量test,賦值為IBM。

下面我們來看兩個代碼:

package test;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.ObjectInputStream;

import java.io.ObjectOutputStream;

import java.io.OutputStream;

public class Main{

public static void main(String[] args){

Person person = new Person();

person.setAge(25);

person.setName("YXY");

Person.test="JAVA"; //modify the test value

File file = new File("c:/test.txt");

try {

OutputStream out = new FileOutputStream(file);

ObjectOutputStream objout = new ObjectOutputStream(out);

objout.writeObject(person);

objout.close();

} catch (IOException e) {

e.printStackTrace();

}

//code segment 1

Person perobj = null;

try {

InputStream in = new FileInputStream(file);

ObjectInputStream objin = new ObjectInputStream(in);

perobj = (Person)objin.readObject();

System.out.println(perobj.test);

in.close();

} catch (IOException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

}在這段代碼里,一開始我們就改了static變量test的值為JAVA,然后在code segment 1上面我們首先實現了序列化,接著我們在code segment 1下面實現了反序列化,讀取對象,運行,我們發現結果是JAVA,這時大家要問了,說不序列化static變量,怎么讀取出來的反序列化對象的值,test的值還改變呢?這正是因為我們并沒有序列化static變量,所以它并沒有被寫入流中,所以當我們要讀取test的值時,它不可能在反序列化的文件里找到新的值,而是去全局數據區取值,因為全局數據區的值現在是JAVA,所以讀取出來的值就是改變后的值JAVA了。

下面我們再看一段代碼:

package test;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.ObjectInputStream;

public class TEST {

public static void main(String[] args){

File file = new File("c:/test.txt");

//code segment 1

Person perobj = null;

try {

InputStream in = new FileInputStream(file);

ObjectInputStream objin = new ObjectInputStream(in);

perobj = (Person)objin.readObject();

System.out.println(perobj.test);

in.close();

} catch (IOException e) {

e.printStackTrace();

} catch (ClassNotFoundException e) {

e.printStackTrace();

}

}

}同樣也是反序列化操作,只不過放到了另一個文件里,這時再運行,結果就是IBM,不再是之前的JAVA,正是因為我們并沒有序列化static變量,所以test的值并不會改變,因為運行這個文件時,全局數據區里的static變量也沒有改,所以它一如既往的是它的原始值IBM。

總結,綜上所述,Java序列化是不能序列化static變量的,大家在使用的時候一定不要混淆。

原文:http://blog.csdn.net/yangxiangyuibm/article/details/43227457

總結

以上是生活随笔為你收集整理的java 变量序列化_Java序列化与静态变量的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。