网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.用Java实现断点续传.
.Java教程电子文档下载.
.参数上溯造型解决了错误的方法调.
.人们眼中的安全.
.每个Java初学者都应该搞懂的六个.
.[java技术] Java常用术语解释.
.第一讲 Java语言概述.
.Java网络编程之传输控制协议(三).
.Java程序的反加密.
.Java,Beans 和 关系数据库 的 镜.
.Java学习之踏上旅途的第一步.
.toLocaleLowerCase 方法.
.敏捷开发技巧-消除代码异味.
.编写高级应用程序2.
.Cocoon2的安装.
.J2EE开发n层应用.
.java 1.4中工具的改变和更新.
.setHours 方法.
.精通ejb(8).
.高手为你解读J2EE开发过程中的异.

J2ME学习——RMS从入门到精通之二

发表日期:2008-1-5



  在系列之一中,我们着重讲述了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中设计序列化的类的时候也应该尽量这样做,避免不必要得麻烦。
上一篇:J2ME学习——RMS从入门到精通之一 人气:650
下一篇:J2ME技术在手机开发领域的优势和不足 人气:654
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐