日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

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

發布時間:2023/12/9 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 zlib库compress和uncompress函数的使用方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

zlib(http://zlib.net/)提供了簡潔高效的In-Memory數據壓縮和解壓縮系列API函數,很多應用都會用到這個庫,其中compress和uncompress函數是最基本也是最常用的。不過很奇怪的是,compress和uncompress函數盡管已經非常的簡單,卻仍然有不少人用得不好,其實歸根結底還是在于有些事情沒有弄明白,這里大家先看下面的代碼。

[cpp] view plaincopy
  • #include?<stdlib.h>??
  • #include?<string.h>??
  • #include?<stdio.h>??
  • #include?<zlib.h>??
  • ??
  • int?main(int?argc,?char*?argv[])??
  • {??
  • ????char?text[]?=?"zlib?compress?and?uncompress?test\nturingo@163.com\n2012-11-05\n";??
  • ????uLong?tlen?=?strlen(text)?+?1;??/*?需要把字符串的結束符'\0'也一并處理?*/??
  • ????char*?buf?=?NULL;??
  • ????uLong?blen;??
  • ??
  • ????/*?計算緩沖區大小,并為其分配內存?*/??
  • ????blen?=?compressBound(tlen);?/*?壓縮后的長度是不會超過blen的?*/??
  • ????if((buf?=?(char*)malloc(sizeof(char)?*?blen))?==?NULL)??
  • ????{??
  • ????????printf("no?enough?memory!\n");??
  • ????????return?-1;??
  • ????}??
  • ??
  • ????/*?壓縮?*/??
  • ????if(compress(buf,?&blen,?text,?tlen)?!=?Z_OK)??
  • ????{??
  • ????????printf("compress?failed!\n");??
  • ????????return?-1;??
  • ????}??
  • ??
  • ????/*?解壓縮?*/??
  • ????if(uncompress(text,?&tlen,?buf,?blen)?!=?Z_OK)??
  • ????{??
  • ????????printf("uncompress?failed!\n");??
  • ????????return?-1;??
  • ????}??
  • ??
  • ????/*?打印結果,并釋放內存?*/??
  • ????printf("%s",?text);??
  • ????if(buf?!=?NULL)??
  • ????{??
  • ????????free(buf);??
  • ????????buf?=?NULL;??
  • ????}??
  • ??
  • ????return?0;??
  • }??
  • zlib處理的對象是Bytef*字節流,很多人遇到字符串就會混淆了,其實很簡單,字節流是沒有結束符的,需要配備長度信息,所以處理字符串的時候需要把結束符也當成一個普通的字節,這樣計算長度的時候也需要算它一份。另外絕大部分人都想動態分配緩沖區,也就是說需要多少再給多少,其實zlib本身有提供compressBound函數用于計算壓縮后緩沖區長度的上限值,不需要額外再設計一些不適當的預測算法,不過解壓縮的時候沒有提供長度的預測,由于compress和uncompress一般都是成對使用的,預先保存好原文的長度即可。

    總結

    以上是生活随笔為你收集整理的zlib库compress和uncompress函数的使用方法的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。