Raj*_*ani 20
这是一个zLib inflate例程,它在内存中占用缓冲区并解压缩到提供的输出缓冲区中.这是一个"一次性"功能,因为它试图一次性膨胀整个输入缓冲区,并假设你已经给它足够的空间来适应它.还可以编写多镜头功能,根据需要动态增长目标缓冲区.
int inflate(const void *src, int srcLen, void *dst, int dstLen) {
z_stream strm = {0};
strm.total_in = strm.avail_in = srcLen;
strm.total_out = strm.avail_out = dstLen;
strm.next_in = (Bytef *) src;
strm.next_out = (Bytef *) dst;
strm.zalloc = Z_NULL;
strm.zfree = Z_NULL;
strm.opaque = Z_NULL;
int err = -1;
int ret = -1;
err = inflateInit2(&strm, (15 + 32)); //15 window bits, and the +32 tells zlib to to detect if using gzip or zlib
if (err == Z_OK) {
err = inflate(&strm, Z_FINISH);
if (err == Z_STREAM_END) {
ret = strm.total_out;
}
else {
inflateEnd(&strm);
return err;
}
}
else {
inflateEnd(&strm);
return err;
}
inflateEnd(&strm);
return ret;
}
Run Code Online (Sandbox Code Playgroud)
说明:
src:包含压缩(gzip或zlib)数据的源缓冲区
srcLen:源缓冲区
dst的长度:目标缓冲区,输出将写入
dstLen:目标缓冲区的长度
返回值:
Z_BUF_ERROR:如果dstLen不足以容纳膨胀的数据
Z_MEM_ERROR:如果没有足够的内存来执行解压缩
Z_DATA_ERROR:如果输入数据已损坏
否则,返回值是写入dst的字节数.
| 归档时间: |
|
| 查看次数: |
10750 次 |
| 最近记录: |