Zlib的deflate, z_stream结构的使用

Zlib的deflate, z_stream结构的使用

 

使用deflate进行压缩时,先要定义z_stream结构体,

先将z_stream的zalloc, zfree, opaque偏量设为Z_NULL, 再调用

deflateInit函数初始化z_stream结构,初始化时主要是用z_stream结构与Z_DEFAULT_COMPRESSION和默认压缩来初始化,

 

初始化好后,再要初始化四个重要分量,为被压缩源字符串next_in,被压源字符串的长度avail_in,压缩后字符串的最大长度(avail_out),压缩后字符串的存放缓冲区(next_out)。

 

     设好后,还得设一个参数即刷新方式flush, 这个参数是deflate函数的第二个参数,一般设为Z_FINISH, 或者Z_NO_FLUSH, 如果是读的文件取字符串

可以使用flush = feof(source) ? Z_FINISH : Z_NO_FLUSH再设定。

 

    以z_stream, flush为参数,调用deflate函数后,这时开始的next_out指向的内存中就有压缩的字符串了,但next_out, avail_out都会发生变化,其具体的变化是,avail_out会变为剩下的还没有使用的最大空间数,而next_out是指的原来的原来的指针加上所读的字符串,

 

压缩后,可以通过最大压缩后所以空间大小减avail_out得压缩后串大小,通过原来的压缩串指针得压缩后字符串。

如果有任何错误,调用deflateEnd函数,当avail_out等于零时,表示加密串满了,则还要压,不过一般不可能因为压缩串不可能大于源串,如果加密串没满,那么,确认一下avail_in是否为0, 表示把源串全压了,再通过flush的值判断是否再压。

 

以上完成了一次压缩

 

转自:http://blog.sina.com.cn/s/blog_625cce080100k187.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
z_stream 是一个结构体,用于 zlib 压缩库中的数据压缩和解压缩操作。下面是一个简单的示例代码,展示了如何使用 z_stream 进行数据压缩和解压缩: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <zlib.h> #define CHUNK_SIZE 1024 int compress_data(char *input, int input_len, char *output, int output_len) { z_stream strm; int ret; unsigned have; unsigned char in[CHUNK_SIZE]; unsigned char out[CHUNK_SIZE]; // 初始化 z_stream 结构体 memset(&strm, 0, sizeof(strm)); strm.zalloc = Z_NULL; strm.zfree = Z_NULL; strm.opaque = Z_NULL; // 初始化压缩器 ret = deflateInit(&strm, Z_DEFAULT_COMPRESSION); if (ret != Z_OK) { return ret; } // 开始压缩数据 strm.next_in = (unsigned char*)input; strm.avail_in = input_len; do { strm.avail_out = CHUNK_SIZE; strm.next_out = out; ret = deflate(&strm, Z_FINISH); have = CHUNK_SIZE - strm.avail_out; memcpy(output, out, have); output += have; output_len -= have; } while (strm.avail_out == 0); // 结束压缩 deflateEnd(&strm); return output_len; } int decompress_data(char *input, int input_len, char *output, int output_len) { z_stream strm; int ret; unsigned have; unsigned char in[CHUNK_SIZE]; unsigned char out[CHUNK_SIZE]; // 初始化 z_stream 结构体 memset(&strm, 0, sizeof(strm)); strm.zalloc = Z_NULL; strm.zfree = Z_NULL; strm.opaque = Z_NULL; // 初始化解压器 ret = inflateInit(&strm); if (ret != Z_OK) { return ret; } // 开始解压数据 strm.next_in = (unsigned char*)input; strm.avail_in = input_len; do { strm.avail_out = CHUNK_SIZE; strm.next_out = out; ret = inflate(&strm, Z_NO_FLUSH); switch (ret) { case Z_NEED_DICT: ret = Z_DATA_ERROR; case Z_DATA_ERROR: case Z_MEM_ERROR: inflateEnd(&strm); return ret; } have = CHUNK_SIZE - strm.avail_out; memcpy(output, out, have); output += have; output_len -= have; } while (strm.avail_out == 0); // 结束解压 inflateEnd(&strm); return output_len; } int main() { char input[] = "Hello, world!"; char compressed[1024] = {0}; char decompressed[1024] = {0}; int compressed_len, decompressed_len; compressed_len = compress_data(input, strlen(input), compressed, sizeof(compressed)); printf("Compressed data: %s\n", compressed); decompressed_len = decompress_data(compressed, compressed_len, decompressed, sizeof(decompressed)); printf("Decompressed data: %s\n", decompressed); return 0; } ``` 这个示例代码中,我们首先定义了一个 CHUNK_SIZE 常量,代表每次压缩或解压数据的大小。接着,在 compress_data 函数中,我们初始化了一个 z_stream 结构体,然后使用 deflateInit 函数初始化压缩器。接着,我们将要压缩的数据传入栈中的 in 数组,然后不断调用 deflate 函数进行压缩,直到输入数据全部被压缩完成。最后,我们使用 deflateEnd 函数结束压缩。 在 decompress_data 函数中,我们同样初始化了一个 z_stream 结构体,然后使用 inflateInit 函数初始化解压器。接着,我们将要解压的数据传入栈中的 in 数组,然后不断调用 inflate 函数进行解压,直到输入数据全部被解压完成。最后,我们使用 inflateEnd 函数结束解压。 在 main 函数中,我们定义了一个字符串 input,将其压缩后,再将其解压。最后,我们输出了压缩前后的数据,以验证数据压缩和解压的正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值