在C++中對數據進行gzip壓縮的流程通常如下:
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <vector>
#include <zlib.h>
std::vector<unsigned char> compress_data(const std::string& data)
{
z_stream zs;
memset(&zs, 0, sizeof(zs));
if (deflateInit2(&zs, Z_BEST_COMPRESSION, Z_DEFLATED, 15 + 16, 8, Z_DEFAULT_STRATEGY) != Z_OK)
throw(std::runtime_error("deflateInit2 failed while compressing."));
zs.next_in = (Bytef*)data.data();
zs.avail_in = data.size();
int ret;
char outbuffer[32768];
std::vector<unsigned char> outdata;
do {
zs.next_out = reinterpret_cast<Bytef*>(outbuffer);
zs.avail_out = sizeof(outbuffer);
ret = deflate(&zs, Z_FINISH);
if (outdata.size() < zs.total_out) {
outdata.insert(outdata.end(), outbuffer, outbuffer + sizeof(outbuffer) - zs.avail_out);
}
} while (zs.avail_out == 0);
deflateEnd(&zs);
return outdata;
}
std::string decompress_data(const std::vector<unsigned char>& data)
{
z_stream zs;
memset(&zs, 0, sizeof(zs));
if (inflateInit2(&zs, 16 + MAX_WBITS) != Z_OK)
throw(std::runtime_error("inflateInit2 failed while decompressing."));
zs.next_in = (Bytef*)data.data();
zs.avail_in = data.size();
int ret;
char outbuffer[32768];
std::string outdata;
do {
zs.next_out = reinterpret_cast<Bytef*>(outbuffer);
zs.avail_out = sizeof(outbuffer);
ret = inflate(&zs, 0);
if (outdata.size() < zs.total_out) {
outdata.append(outbuffer, sizeof(outbuffer) - zs.avail_out);
}
} while (ret == Z_OK);
inflateEnd(&zs);
return outdata;
}
int main()
{
std::string original_data = "This is some test data to compress.";
std::vector<unsigned char> compressed_data = compress_data(original_data);
std::string decompressed_data = decompress_data(compressed_data);
std::cout << "Original Data: " << original_data << std::endl;
std::cout << "Compressed Data: " << compressed_data.size() << std::endl;
std::cout << "Decompressed Data: " << decompressed_data << std::endl;
return 0;
}
以上就是在C++中進行gzip壓縮的基本流程,需要注意使用zlib庫提供的函數來實現壓縮和解壓縮操作。