Java压缩技术(一) ZLib

应好友需要,整理一下Java的压缩算法,先从ZLib开始。 :D

相关链接:
[url=http://snowolf.iteye.com/blog/465433]Java压缩技术(一) ZLib[/url]
[url=http://snowolf.iteye.com/blog/642298]Java压缩技术(二) ZIP压缩——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/642492]Java压缩技术(三) ZIP解压缩——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/643010]Java压缩技术(四) GZIP——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/643443]Java压缩技术(五) GZIP相关——浏览器解析[/url]
[url=http://snowolf.iteye.com/blog/644591]Java压缩技术(六) BZIP2——Commons实现[/url]
[url=http://snowolf.iteye.com/blog/648652]Java压缩技术(七) TAR——Commons实现[/url]

有关ZLib可参见官方主页 [url]http://www.zlib.net/[/url]
ZLib可以简单的理解为压缩/解压缩算法,它与ZIP、RAR等归档算法有所不同,与bzip2比较接近。

压缩工具代码如下:

/**
* 2009-9-9
*/
package org.zlex.commons.io;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.zip.Deflater;
import java.util.zip.DeflaterOutputStream;
import java.util.zip.Inflater;
import java.util.zip.InflaterInputStream;

/**
* ZLib压缩工具
*
* @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>
* @version 1.0
* @since 1.0
*/
public abstract class ZLibUtils {

/**
* 压缩
*
* @param data
* 待压缩数据
* @return byte[] 压缩后的数据
*/
public static byte[] compress(byte[] data) {
byte[] output = new byte[0];

Deflater compresser = new Deflater();

compresser.reset();
compresser.setInput(data);
compresser.finish();
ByteArrayOutputStream bos = new ByteArrayOutputStream(data.length);
try {
byte[] buf = new byte[1024];
while (!compresser.finished()) {
int i = compresser.deflate(buf);
bos.write(buf, 0, i);
}
output = bos.toByteArray();
} catch (Exception e) {
output = data;
e.printStackTrace();
} finally {
try {
bos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
compresser.end();
return output;
}

/**
* 压缩
*
* @param data
* 待压缩数据
*
* @param os
* 输出流
*/
public static void compress(byte[] data, OutputStream os) {
DeflaterOutputStream dos = new DeflaterOutputStream(os);

try {
dos.write(data, 0, data.length);

dos.finish();

dos.flush();
} catch (IOException e) {
e.printStackTrace();
}
}

/**
* 解压缩
*
* @param data
* 待压缩的数据
* @return byte[] 解压缩后的数据
*/
public static byte[] decompress(byte[] data) {
byte[] output = new byte[0];

Inflater decompresser = new Inflater();
decompresser.reset();
decompresser.setInput(data);

ByteArrayOutputStream o = new ByteArrayOutputStream(data.length);
try {
byte[] buf = new byte[1024];
while (!decompresser.finished()) {
int i = decompresser.inflate(buf);
o.write(buf, 0, i);
}
output = o.toByteArray();
} catch (Exception e) {
output = data;
e.printStackTrace();
} finally {
try {
o.close();
} catch (IOException e) {
e.printStackTrace();
}
}

decompresser.end();
return output;
}

/**
* 解压缩
*
* @param is
* 输入流
* @return byte[] 解压缩后的数据
*/
public static byte[] decompress(InputStream is) {
InflaterInputStream iis = new InflaterInputStream(is);
ByteArrayOutputStream o = new ByteArrayOutputStream(1024);
try {
int i = 1024;
byte[] buf = new byte[i];

while ((i = iis.read(buf, 0, i)) > 0) {
o.write(buf, 0, i);
}

} catch (IOException e) {
e.printStackTrace();
}
return o.toByteArray();
}
}


测试用例代码如下:

/**
* 2009-9-9
*/
package org.zlex.commons.io;

import static org.junit.Assert.*;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;

import org.junit.Test;

/**
* ZLib压缩测试用例
*
* @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>
* @version 1.0
* @since 1.0
*/
public class ZLibUtilsTest {

@Test
public final void testBytes() {
System.err.println("字节压缩/解压缩测试");
String inputStr = "snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org";
System.err.println("输入字符串:\t" + inputStr);
byte[] input = inputStr.getBytes();
System.err.println("输入字节长度:\t" + input.length);

byte[] data = ZLibUtils.compress(input);
System.err.println("压缩后字节长度:\t" + data.length);

byte[] output = ZLibUtils.decompress(data);
System.err.println("解压缩后字节长度:\t" + output.length);
String outputStr = new String(output);
System.err.println("输出字符串:\t" + outputStr);

assertEquals(inputStr, outputStr);
}

@Test
public final void testFile() {
String filename = "zlib";
File file = new File(filename);
System.err.println("文件压缩/解压缩测试");
String inputStr = "snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org";
System.err.println("输入字符串:\t" + inputStr);
byte[] input = inputStr.getBytes();
System.err.println("输入字节长度:\t" + input.length);

try {

FileOutputStream fos = new FileOutputStream(file);
ZLibUtils.compress(input, fos);
fos.close();
System.err.println("压缩后字节长度:\t" + file.length());
} catch (Exception e) {
fail(e.getMessage());
}

byte[] output = null;

try {
FileInputStream fis = new FileInputStream(file);
output = ZLibUtils.decompress(fis);
fis.close();

} catch (Exception e) {
fail(e.getMessage());
}
System.err.println("解压缩后字节长度:\t" + output.length);
String outputStr = new String(output);
System.err.println("输出字符串:\t" + outputStr);

assertEquals(inputStr, outputStr);
}
}


输入结果

字节压缩/解压缩测试
输入字符串: snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org
输入字节长度: 59
压缩后字节长度: 39
解压缩后字节长度: 59
输出字符串: snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org
文件压缩/解压缩测试
输入字符串: snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org
输入字节长度: 59
压缩后字节长度: 39
解压缩后字节长度: 59
输出字符串: snowolf@zlex.org;dongliang@zlex.org;zlex.dongliang@zlex.org



应该怎么计算呢?原数据长度59字节,压缩后39字节,大约是33%的压缩率!

ZLib压缩对大字节数据压缩,才能反映出压缩效果。 :D
先占个位儿,回头细致整理! :D

相关链接:
[url=http://snowolf.iteye.com/blog/465433]Java压缩技术(一) ZLib[/url]
[url=http://snowolf.iteye.com/blog/642298]Java压缩技术(二) ZIP压缩——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/642492]Java压缩技术(三) ZIP解压缩——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/643010]Java压缩技术(四) GZIP——Java原生实现[/url]
[url=http://snowolf.iteye.com/blog/643443]Java压缩技术(五) GZIP相关——浏览器解析[/url]
[url=http://snowolf.iteye.com/blog/644591]Java压缩技术(六) BZIP2——Commons实现[/url]
[url=http://snowolf.iteye.com/blog/648652]Java压缩技术(七) TAR——Commons实现[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值