现在的位置: 首页 > 综合 > 正文

zlib库compress和uncompress函数的使用方法

2013年10月23日 ⁄ 综合 ⁄ 共 1474字 ⁄ 字号 评论关闭

From:

http://blog.csdn.net/turingo/article/details/8148264

zlib(http://zlib.net/)提供了简洁高效的In-Memory数据压缩和解压缩系列API函数,很多应用都会用到这个库,其中compress和uncompress函数是最基本也是最常用的。不过很奇怪的是,compress和uncompress函数尽管已经非常的简单,却仍然有不少人用得不好,其实归根结底还是在于有些事情没有弄明白,这里大家先看下面的代码。

  1. #include <stdlib.h>  
  2. #include <string.h>  
  3. #include <stdio.h>  
  4. #include <zlib.h>  
  5.   
  6. int main(int argc, char* argv[])  
  7. {  
  8.     char text[] = "zlib compress and uncompress test\nturingo@163.com\n2012-11-05\n";  
  9.     uLong tlen = strlen(text) + 1;  /* 需要把字符串的结束符'\0'也一并处理 */  
  10.     char* buf = NULL;  
  11.     uLong blen;  
  12.   
  13.     /* 计算缓冲区大小,并为其分配内存 */  
  14.     blen = compressBound(tlen); /* 压缩后的长度是不会超过blen的 */  
  15.     if((buf = (char*)malloc(sizeof(char) * blen)) == NULL)  
  16.     {  
  17.         printf("no enough memory!\n");  
  18.         return -1;  
  19.     }  
  20.   
  21.     /* 压缩 */  
  22.     if(compress(buf, &blen, text, tlen) != Z_OK)  
  23.     {  
  24.         printf("compress failed!\n");  
  25.         return -1;  
  26.     }  
  27.   
  28.     /* 解压缩 */  
  29.     if(uncompress(text, &tlen, buf, blen) != Z_OK)  
  30.     {  
  31.         printf("uncompress failed!\n");  
  32.         return -1;  
  33.     }  
  34.   
  35.     /* 打印结果,并释放内存 */  
  36.     printf("%s", text);  
  37.     if(buf != NULL)  
  38.     {  
  39.         free(buf);  
  40.         buf = NULL;  
  41.     }  
  42.   
  43.     return 0;  
  44. }  

zlib处理的对象是Bytef*字节流,很多人遇到字符串就会混淆了,其实很简单,字节流是没有结束符的,需要配备长度信息,所以处理字符串的时候需要把结束符也当成一个普通的字节,这样计算长度的时候也需要算它一份。另外绝大部分人都想动态分配缓冲区,也就是说需要多少再给多少,其实zlib本身有提供compressBound函数用于计算压缩后缓冲区长度的上限值,不需要额外再设计一些不适当的预测算法,不过解压缩的时候没有提供长度的预测,由于compress和uncompress一般都是成对使用的,预先保存好原文的长度即可。

抱歉!评论已关闭.