前面的一篇文章说明了压缩以及解压缩,但是对于字节流的分析表示,上次的压缩满足不了(或者说满足起来显得复杂)现在开发要求,及我们可以直接从压缩文件中读取到文件大小以及压缩文件大小,方便直接解析使用。
上次采用的基本上是存储模式压缩,不记录文件的大小以及压缩文件大小。改变后采用真正的压缩模式压缩,采用zip给定的压缩算法实现。
具体的压缩代码。
final static public void zip(String srcfile, String destfile) {
try {
BufferedInputStream origin = null;
ZipOutputStream out = new ZipOutputStream(new BufferedOutputStream(
new FileOutputStream(destfile)));
File f = new File(srcfile);
Vector v = new Vector();
v = parse(f.listFiles(), v);
File file = null;
String path = null;
ZipEntry entry = null;
byte[] data = null;
CRC32 crc = null;
for (int i = 0; i < v.size(); i++) {
file = (File) v.elementAt(i);
path = path(srcfile, file.getAbsolutePath());
if (file.isFile()) {
origin = new BufferedInputStream(new FileInputStream(file),
BUFFER);
entry = new ZipEntry(path);
data = new byte[origin.available()];
origin.read(data);
byte[] deflater = new byte[1000];
Deflater de = new Deflater(Deflater.DEFAULT_COMPRESSION,
true);
de.setInput(data);
de.finish();
de.deflate(deflater, 0, deflater.length);
entry.setMethod(ZipEntry.DEFLATED);
entry.setSize(de.getBytesRead());
entry.setCompressedSize(de.getBytesWritten());
crc = new CRC32();
crc.update(data);
entry.setCrc(crc.getValue());
out.setMethod(ZipOutputStream.DEFLATED);
out.setLevel(Deflater.DEFAULT_COMPRESSION);
out.putNextEntry(entry);
out.write(data, 0, data.length);
} else {
entry = new ZipEntry(path + "/");
out.putNextEntry(entry);
}
out.flush();
out.closeEntry();
}
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
其余部分代码参见http://gao-20022002.iteye.com/blog/271319
,这篇文章只是改进了压缩实现。
关于zip文件的压缩算法,具体参见http://gao-20022002.iteye.com/blog/273714
。
分享到:
相关推荐
即使创建压缩文件时指定了 .zip 扩展名,它仍然是 RAR 格式的。Windows 用户 可以 WinRAR,它支持更多的压缩文件类型,包括 RAR 和 ZIP 格式。 WinRAR 提供了图形用户界面和命令行模式。虽然控制台 RAR 和图形...
运行AusLogics Registry Defrag后,在出现的界面中选择“继续”按钮,就开始进行注册表分析了,在进行注册表分析前建议关闭其它正在运行的应用程序,软件将自动创建还原点并对注册表数据文件进行扫描,在扫描过程中...
NTFS 符号链接和分析点为链接,它们的内容没有被压缩。此选项的命令行等价开关是 -ol。 NTFS 硬链接的类似选项是“把硬链接保存为链接”。它的命令行等价开关是 -oh。 这两个选项仅可用于 RAR 5.0 压缩文件...
智能:智能设定行为分析,去除繁琐的软件设置,把复杂的事情都交给程序。 吉星抽奖软件功能 1.支持 "文字/数字抽奖" 、"图片抽奖" 、 "图片 文字" 三种抽奖模式,根据不同应用随意切换 2.支持文字隐私保护抽奖 (如...
此程序从国服TBC时代就开始使用,后来转战台服也仍然继续使用,但一直没有开放给其他人使用,只是自己自娱自乐使 用.运行原理NextActions是一个标准的wow lua插件,她调用wow API分析当前游戏角色及目标状态数据,计算...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
Java zip压缩包查看程序,应用弹出文件选择框,选择ZIP格式的压缩文件,可以像Winrar软件一样查看压缩文件内部的文件及文件夹,源码截图如上所示。 Java 数字签名、数字证书生成源码 2个目标文件 摘要:JAVA源码,...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
Java zip压缩包查看程序,应用弹出文件选择框,选择ZIP格式的压缩文件,可以像Winrar软件一样查看压缩文件内部的文件及文件夹,源码截图如上所示。 Java 数字签名、数字证书生成源码 2个目标文件 摘要:JAVA源码,...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...
可以将列表数据缓存到redis中,其他kv结构数据继续缓存到memcached 6. 支持redis的主从集群,可以做读写分离。缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL...