`

java压缩对象 与 对象的序列化

 
阅读更多

gzip是目前广泛应用的一种压缩方式,它具有很高的压缩比和压缩效率.在sun公司发布的jdk中包含了java.util.zip包,对gzip提供了直接支持.使用java语言可以很方便的实现gzip压缩和解压缩.以下是一个压缩和解压缩的最简程序.


  (压缩:gzip.java)
  import java.io.*;
  import java.util.zip.*;
  public class gzip
  {
  public static void main(String[] args)
  {
  if (args.length !=2)
  {
  System.out.println("Usage:java gzip ");
  System.exit(1);
  }
  try
  {
  //打开需压缩文件作为文件输入流
  FileInputStream fin=new FileInputStream(args[0]);
  //建立压缩文件输出流
  FileOutputStream fout=new FileOutputStream(args[1]);
  //建立gzip压缩输出流
  GZIPOutputStream gzout=new GZIPOutputStream(fout);
  byte[] buf=new byte[1024];//设定读入缓冲区尺寸
  int num;
  while ((num=fin.read(buf)) != -1)
  {
  gzout.write(buf,0,num);
  }
  gzout.close();//!!!关闭流,必须关闭所有输入输出流.保证输入输出完整和释放系统资源.
  fout.close();
  fin.close();
  }catch(IOException e)
  {
  System.out.println(e);
  }
  }
  }
  (解压缩:unzip.java)
  import java.io.*;
  import java.util.zip.*;
  public class ungzip
  {
  public static void main(String[] args)
  {
  if (args.length !=2)
  {
  System.out.println("Usage:java ungzip ");
  System.exit(1);
  }
  try
  {
  //建立gzip压缩文件输入流
  FileInputStream fin=new FileInputStream(args[0]);
  //建立gzip解压工作流
  GZIPInputStream gzin=new GZIPInputStream(fin);
  //建立解压文件输出流
  FileOutputStream fout=new FileOutputStream(args[1]);
  byte[] buf=new byte[1024];
  int num;
  while ((num=gzin.read(buf,0,buf.length)) != -1)
  {
  fout.write(buf,0,num);
  }
  gzin.close();
  fout.close();
  fin.close();
  }catch(IOException e)
  {
  System.out.println(e);

  }
  }
  }

  非面向对象语言要实现保存工作数据(如一个绘图程序保存一幅画面的定义),往往需要一个程序数据格 式转换为外部文件格式存储,工作时再反向转换的过程.实现比较麻烦,编程不透明.而java语言是一种面向对象的语言,使用它的对象序列化特性,就可实现 将工作对象(画面定义对象数据)直接写入硬盘,需要时再直接再读入内存,不需任何额外操作.实现非常 方便.但由于写出对象为java类格式,因此数据冗余度较大.当数据量很大时,往往造成存储文件很大.过多的磁盘操作也导致数据读入花费了更多时间,占有 了大量内存.采用gzip压缩存储对象是解决此类问题的有效手段.(在本人实现的一个监控系 统中,调入一幅测试画面(10万个组件,压缩前7M,压缩后600K),压缩前对如画面后内存为26M,压缩后读入内存为12M,读入速度也大幅提高.效 果十分明显).
  java程序开发网络应用程序是它的最大优势,但在某些低速网络情况下(Internet、拨号网络).网络往往造成传输瓶颈, 影响应用效果,对于实时性要求高的应用影响更大.采用压缩可以有效改善通信效果.
  可见,在java下的对象gzip压缩有着广泛的应用价值.以下是一个简单事例程序.
  (串行化的数据对象文件:Data.java)
  import java.io.*;
网管下载dl.bitscn.com
  import java.util.zip.*;
  public class Data implements Serializable//继承串行序列化接口
  {
  String name="匹配";
  int age=123;
  float height=1.902f;
  }
  (对象压缩解压缩类文件:compressObject.java)
  import java.util.zip.*;
  import java.io.*;
  public final class compressObject
  {
  //将Data类型数据对象序列化对象压缩,返回字节数组,压缩后的对象数组可写入文件保存或用于网络传输
  public static byte[] writeCompressObject(Data object_)
  {
  byte[] data_=null;
  try
  {
  //建立字节数组输出流
  ByteArrayOutputStream o = new ByteArrayOutputStream();
  //建立gzip压缩输出流
  GZIPOutputStream gzout=new GZIPOutputStream(o);
  //建立对象序列化输出流
  ObjectOutputStream out = new ObjectOutputStream(gzout);
  out.writeObject(object_);
  out.flush();
  out.close();
  gzout.close();
  //返回压缩字节流
  data_=o.toByteArray();
  o.close();

  }catch(IOException e)
  {
  System.out.println(e);
  }
  return(data_);
  }
  //将压缩字节数组还原为Data类型数据对象
  public static Data readCompressObject(byte[] data_)
  {
  Data object_=null;
  try
  {
  //建立字节数组输入流
  ByteArrayInputStream i = new ByteArrayInputStream(data_);
  //建立gzip解压输入流
  GZIPInputStream gzin=new GZIPInputStream(i);
  //建立对象序列化输入流
  ObjectInputStream in = new ObjectInputStream(gzin);
  //按制定类型还原对象
  object_=(Data)in.readObject();
  i.close();
  gzin.close();
  in.close();
  }catch(ClassNotFoundException e)
  {
  System.out.println(e);
  }catch(IOException e)
  {
  System.out.println(e);
  }
  return(object_);
  }
  }
  (主程序:test.java)
  import java.io.*;
  import java.util.zip.*;
  public class test
  {
  public static void main(String[] args)
  {
  Data testData_=new Data();
  //未压缩数据对象内容
  System.out.println("name="+testData_.name+" age="+testData_.age+" height="+testData_.height);
  //压缩
  byte[] i_=compressObject.writeCompressObject(testData_);
  /*
  可执行保存或网络传输,需要时还原或在对端还原
  */
  //解压缩
  Data o_=compressObject.readCompressObject(i_);
  //解压缩后对象内容
  System.out.println("name="+o_.name+" age="+o_.age+" height="+o_.height);
  }
  }

----------------------+---------------------+------------------------------------

序列化:

1 ObjectOutputStreamoos = new ObjectOutputStream( new java.util.zip.GZIPOutputStream(
2 new FileOutputStream(outputFile)));
3 oos.writeObject(obj);
4 oos.close();

反序列化:

1 ObjectInputStreamois = new ObjectInputStream( new java.util.zip.GZIPInputStream(
2 new FileInputStream(userFile)));
3 Objectobj = ois.readObject();
4 ois.close();

(上述出自:http://www.blogjava.net/Andyluo/archive/2005/06/23/6609.html )
分享到:
评论

相关推荐

    自己实现的protobuf 压缩类,并能序列化反序列化

    序列化是将对象的状态转化为可存储或可传输的形式的过程,而反序列化则是将这种形式的数据恢复为原来的对象状态。在protobuf中,开发者定义数据结构的协议文件(.proto文件),然后生成对应的源代码,这些源代码提供...

    FST:快速Java序列化的替代品

    3. **JDK兼容**:FST设计上与Java的标准序列化接口兼容,这意味着可以轻松地替换现有的序列化代码,而无需大规模重构。 4. **自定义序列化**:FST支持用户自定义序列化策略,对于特殊类型的数据结构,可以提供更...

    加快Java的文件序列化速度

    在Java编程中,文件序列化是一个常见的操作,用于将对象的状态转换为字节流,以便存储或在网络上传输。然而,序列化过程可能会消耗大量时间,尤其是在处理大量数据时。以下是一些加快Java文件序列化速度的方法: 1....

    Java 序列化教程含代码

    我们使用 SerializeDemo 程序将 Employee 对象序列化到一个文件中,并使用 DeserializeDemo 程序将其反序列化回来。 序列化的优点: 1. 永久保存对象状态:序列化机制使得对象可以被写入文件中,并在需要时从文件...

    几种序列化的实现方法 java自带, Writable, Avro

    与Java序列化相比,它更加轻量级且性能更好。每个可序列化的类型(如IntWritable, Text等)都实现了`write()`和`readFields()`方法,用于写入和读取数据到DataOutput和DataInput流。然而,Writable接口有一些局限性...

    Java序列化(Serializable)与反序列化_.docx

    2. **Java对象序列化**:使用Java内置的序列化机制,适用于纯Java环境,能保持对象的所有信息。 3. **Protobuf**:Google提供的高效协议缓冲区方案,适合于需要高度压缩场景下的序列化需求。 #### Java序列化的基本...

    对象序列化TCP传输

    对象序列化是将一个对象的状态转换为可存储或可传输的形式的过程,这在分布式系统、网络通信和持久化存储中非常常见。TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议。...

    Json序列化与反序列化

    总结来说,JSON序列化与反序列化是现代Web开发中不可或缺的一部分,它提供了数据交换的标准格式,使得不同语言和平台之间的数据交互变得简单高效。正确理解和使用这一技术,能够极大地提升开发效率和软件的可维护性...

    Java二进制序列化与克隆快速、高效、自动化.zip

    Kryo 是一个快速高效的 Java 二进制对象图序列化框架。该项目的目标是实现高速、小尺寸和易于使用的 API。当需要将对象持久化时,无论是将对象持久化到文件、数据库还是通过网络,该项目都非常有用。Kryo 还可以自动...

    Image类的序列化

    在Java或其他编程语言中,序列化通常用于持久化对象状态,即把内存中的对象转化为字节流,以便保存到磁盘、数据库,或者在网络上传输。在Java中,`Image`类的序列化涉及到对图像数据的处理,这在很多场景下都非常...

    序列化和反序列化doc文档.rar

    在Java中,我们可以通过实现`Serializable`接口来标记一个类为可序列化的;在Python中,可以使用pickle或者json模块进行序列化操作。 反序列化则恰恰相反,它是将序列化后的数据恢复为原来的对象状态。这个过程需要...

    redis字节码存压缩对象

    这些工具可能包括序列化/反序列化方法,用于将Java对象转换为适合Redis存储的字节码格式,以及压缩和解压缩方法。 - 这样的工具类能够帮助开发者更高效地与 Redis 交互,提高代码的可读性和可维护性,同时降低出错...

    java源码:Java存储与读取对象.rar

    在Java编程中,存储和读取对象是一项...在提供的压缩文件`codefans.net`中可能包含了实现这一过程的具体示例代码,通过查看和学习这些代码,你可以更深入地了解Java对象的序列化和反序列化机制,并应用到自己的项目中。

    两个Activity在调用StartActivity的时候传递序列化信息

    在Java和Android中,如果一个类要实现序列化,它需要实现Serializable接口,无需实现任何方法,只是表明该类的对象可以被序列化。 以下是两个Activity之间传递序列化对象的步骤: 1. **创建可序列化的对象**:确保...

    序列和反序列案例

    在提供的压缩文件“序列和反序列”中,可能包含了一些示例代码,展示了如何在Java中实现序列化和反序列化的过程。这些例子可能包括了如何创建可序列化的类、如何处理序列化过程中可能出现的问题,以及如何优化序列化...

    浅析若干Java序列化工具编程开发技术共13页.pdf.z

    在Java中,内置的序列化接口`java.io.Serializable`允许对象被写入到流中(如文件或网络连接),然后在需要时重新构造。实现这个接口的对象可以被序列化和反序列化。Java标准库提供了`ObjectOutputStream`和`...

    fastJosn Gson Jackson 序列化和反序列化所需要的jarlib.rar

    在Java开发中,序列化和反序列化是数据转换的重要环节,主要用于将对象转换为可存储或传输的数据格式,如JSON字符串,以及将这些数据还原为原来的对象。本压缩包包含fastJson、Gson和Jackson这三种流行JSON库的jar...

    使用Java序列化实现一个简单的文件备份工具.txt

    #### 一、Java序列化的概念与作用 **Java序列化**是一种将对象的状态(即其成员变量)转换为可以存储或传输的形式的过程。序列化的主要用途包括: 1. **持久化**:将对象的状态保存到磁盘上,以便将来恢复该对象的...

    Java哈夫曼编码的文件的压缩与解压.docx

    本文将围绕Java实现哈夫曼编码的文件压缩与解压进行详细解析。 首先,我们看到`main`方法调用了`zipFile`和`unZipFile`两个静态方法,分别用于文件的压缩和解压缩操作。`zipFile`方法接收源文件路径和目标压缩文件...

Global site tag (gtag.js) - Google Analytics