明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

談?wù)凧2SE中的序列化之一個(gè)感性的認(rèn)識

[摘要]java中處處體現(xiàn)著簡單的程序設(shè)計(jì)風(fēng)格,序列化作為最常用的功能之一,在java中的設(shè)計(jì)尤為“簡單”。在ObjectInputStream 和ObjectOutputStream的幫助下,我們可以輕松的實(shí)現(xiàn)序列化。   只要我們的class 實(shí)現(xiàn)了java.io.Serializable接口,就可...
java中處處體現(xiàn)著簡單的程序設(shè)計(jì)風(fēng)格,序列化作為最常用的功能之一,在java中的設(shè)計(jì)尤為“簡單”。在ObjectInputStream 和ObjectOutputStream的幫助下,我們可以輕松的實(shí)現(xiàn)序列化。 

  只要我們的class 實(shí)現(xiàn)了java.io.Serializable接口,就可以利用ObjectOutputStream的writeObject()方法將一個(gè)對象序列化;利用ObjectInputStream的readObject()方法,可以返回讀出的object對象。Serializable接口不需要我們實(shí)現(xiàn)任何方法。 

  以下是一個(gè)例子,它能給我們一個(gè)感性的認(rèn)識: 

  Serial實(shí)現(xiàn)了就java.io.Serializable接口,是需要序列化的類。我們首先構(gòu)造一個(gè)Serial的對象serial1然后將其保存(序列化)在一個(gè)文件中,而后再將其讀出(反序列化),并打印其內(nèi)容。 

  package Stream; 

/** 
* @author favo yang 
*/ 

import java.io.*; 

public class Serial implements Serializable { 
 int company_id; 
 String company_addr; 
 boolean company_flag; 
 public Serial(){}//不同于c++,沒有也可以 
 public Serial(int company_id,String company_addr,boolean company_flag) { 
  this.company_id=company_id; 
  this.company_addr=company_addr; 
  this.company_flag=company_flag; 
 } 

 public static void main(String[] args) { 
  Serial serial1 = new Serial(752,"dayer street #5 building 02-287",false);//構(gòu)造一個(gè)新的對象 
  FileInputStream in=null; 
  FileOutputStream out=null; 
  ObjectInputStream oin=null; 
  ObjectOutputStream oout=null; 
  try { 
   out = new FileOutputStream("5.txt"); 
   oout = new ObjectOutputStream(out); 
   serial1.serialize(oout);//序列化 
   oout.close(); 
   oout=null; 
   in = new FileInputStream("5.txt"); 
   oin = new ObjectInputStream(in); 
   Serial serial2 = Serial.deserialize(oin);//反序列化 
   System.out.println(serial2);//打印結(jié)果 
  } catch (Exception ex){ 
   ex.printStackTrace(); 
  } finally{ 
   try { 
    if (in != null) { 
     in.close(); 
    } 
    if (oin != null) { 
     oin.close(); 
    } 
    if (out != null) { 
     out.close(); 
    } 
    if (oout != null) { 
     oout.close(); 
    } 
   } catch (IOException ex1) { 
    ex1.printStackTrace(); 
   } 
  } 
 } 

 /** 
  * deserialize 
 */ 

 public static Serial deserialize(ObjectInputStream oin) throws Exception{ 
  Serial s=(Serial)oin.readObject(); 
  return s; 
 } 

 public String toString() { 
  return "DATA: "+company_id+" "+company_addr+" "+company_flag; 
 } 

 /** 
 * serialize 
 */ 

 public void serialize(ObjectOutputStream oout) throws Exception{ 
  oout.writeObject(this); 
 } 

  運(yùn)行結(jié)果: 

  DATA: 752 dayer street #5 building 02-287 false 

  正確打印了結(jié)果。 

  現(xiàn)在序列化的功能還沒有被j2me支持,所以我們在j2me中是使用DataInputStream、DataoutputStream配合rms或者網(wǎng)絡(luò)實(shí)現(xiàn)序列化。