国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

RMS從入門到精通之二

2019-11-18 16:06:25
字體:
來源:轉載
供稿:網友
    在系列之一中,我們著重講述了Record Management System的基礎知識。在介紹如何使用Record Management System之前,我想首先介紹一下java IO以及在J2ME平臺實現序列化的內容,無論對Record Management System還是MIDP中的通用聯網框架來說,上述內容都是非常重要的。

    在CLDC中定義的Java IO是非常短小精悍的,但是也提供了足夠的類來完成我們的IO操作。由于和J2SE的實現是通用的,因此你可以使用J2ME和J2SE或者J2EE平臺進行通信。比如通過聯網和servlet進行通信。在Record Management System中我們主要使用的類是ByteArrayInputStream、ByteArrayOutputStream、DataInputStream和DataOutputStream。前面兩個是基于字節的,ByteArrayInputStream的作用是把字節數組轉換成流而ByteArrayOutputStream的作用是把內存緩沖區內的數據轉換成字節。后面兩個類是基于java基本數據類型和String操作的。通常他們把前面兩個類作為參數傳送給構造器,這樣他們就可以對基本數據類型以及String進行讀寫操作了。值得注意的一點是ByteArrayOutputStream的toByteArray()方法是把內存中的數據進行復制返回,這樣的話多浪費了一份內存,為了更有效的使用有限的存儲空間你可以擴展ByteArrayOutputSteam類然后提供getByteArray()方法,下面是例子:
public class MyByteArrayOutputStream extends ByteArrayOutputStream
{
  public byte[] getByteArray()
  {
    return buf; 
  }
}

    在J2ME中并沒有提供對象序列化的機制,但是我們可以自己實現它。請考慮下面這個類:

public class Bank
{
 PRivate String bankName;
 private String phone;
 private int employeeNum;
 
 public Bank(){}
 
 public Bank(String aBankName,String aPhone,int aEmployeeNum)
 {
  this.bankName = aBankName;
  this.phone = aPhone;
  this.employeeNum = aEmployeeNum;
 }
 
 public String getBankName()
 {
  return bankName !=null?bankName:"";
 }
 
 public String getPhone()
 {
  return phone!=null?phone:"";
 }
 
 public int getEmployeeNum()
 {
  return employeeNum;
 }

}
我們添加兩個方法到這個類來實現對象序列化。如下所示:
public class Bank
{
 private String bankName;
 private String phone;
 private int employeeNum;
 
 public Bank(){}
 
 public Bank(String aBankName,String aPhone,int aEmployeeNum)
 {
  this.bankName = aBankName;
  this.phone = aPhone;
  this.employeeNum = aEmployeeNum;
 }
 
 public String getBankName()
 {
  return bankName !=null?bankName:"";
 }
 
 public String getPhone()
 {
  return phone!=null?phone:"";
 }
 
 public int getEmployeeNum()
 {
  return employeeNum;
 }
 
 public byte[] serialize() throws IOException
 {
  ByteArrayOutputStream bos = new ByteArrayOutputStream();
  DataOutputStream dos = new DataOutputStream(bos);
 
  dos.writeUTF(getBankName());
  dos.writeUTF(getPhone());
  dos.writeInt(getEmployeeNum());
  dos.flush();
 
  return bos.toByteArray();
 }
 
 public Bank deserialize(byte[] data) throws IOException
 {
  ByteArrayInputStream bis = new ByteArrayInputStream(data);
  DataInputStream dis = new DataInputStream(bis);
 
  Bank myBank = new Bank();
  myBank.bankName = dis.readUTF();
  myBank.phone = dis.readUTF();
  myBank.employeeNum = dis.readInt();
 
  return myBank;
 }
}
這樣我們就實現了對象的序列化,使用起來也非常簡單。序列化和反序列化的操作分別如下面所示:
Bank aBank = .....;
RecordStore rs = .....;
try
{
 byte[] data = aBank.serialize();
 rs.addRecord(data,0,data.length);
}


catch(IOException e)
{
 //do something
}

catch(RecordStoreException e)
{
 //do something
}
————————————————————————————

byte[] data = ..........;
Bank aBank = null;
try
{
 aBank = Bank.deserialize(data);
}
catch(IOException e)
{
 
}
    值得注意的一點是在Bank類中我們的成員都是基本數據類型以及String類型,并不存在指向其他對象的引用,這是最理想也是最簡單的情況,事實上我們在J2ME中設計序列化的類的時候也應該盡量這樣做,避免不必要得麻煩。

(出處:http://m.survivalescaperooms.com)



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 五华县| 株洲县| 凤山县| 甘南县| 沛县| 永登县| 嘉禾县| 华安县| 嘉义县| 乌拉特前旗| 靖西县| 麻栗坡县| 卢龙县| 丹阳市| 合肥市| 新巴尔虎左旗| 大方县| 广饶县| 天长市| 蒙自县| 海口市| 垣曲县| 光山县| 大同县| 丹江口市| 鲜城| 乌拉特后旗| 江陵县| 会宁县| 霍邱县| 珲春市| 东海县| 萍乡市| 高安市| 克东县| 当雄县| 泸西县| 丰台区| 临西县| 双江| 余姚市|