![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java JavaScript Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C++) Chunked Compression Using CompressBd2 with FirstChunk and LastChunkSee more Compression ExamplesThis example demonstrates how to compress data in multiple segments using theCompressBd2 method together with the FirstChunk and LastChunk properties. Instead of compressing all data in a single call, the input is divided into smaller chunks and processed sequentially, which is useful when handling streaming data or large inputs.
The example shows how to correctly mark the first, middle, and final chunks so that the compression stream is properly initialized and finalized. The compressed output is accumulated in a separate This approach is ideal for scenarios where data is received incrementally, such as reading from a network stream, processing large files in parts, or handling real-time data feeds.
#include <CkCompression.h> #include <CkBinData.h> void ChilkatSample(void) { bool success = false; // This example assumes the Chilkat API has already been unlocked. // See Global Unlock Sample for sample code. CkCompression compress; compress.put_Algorithm("zlib"); // This will accumulate the compressed output. CkBinData bdOut; // ------------------------------------------------------------------ // Simulate input arriving in chunks. // ------------------------------------------------------------------ const char *part1 = "The quick brown fox "; const char *part2 = "jumps over the lazy dog. "; const char *part3 = "This text is split into chunks."; // ------------------------------------------------------------------ // Compress the first chunk // ------------------------------------------------------------------ compress.put_FirstChunk(true); compress.put_LastChunk(false); CkBinData bdIn; bdIn.AppendString(part1,"utf-8"); success = compress.CompressBd2(bdIn,bdOut); if (success == false) { std::cout << compress.lastErrorText() << "\r\n"; return; } // ------------------------------------------------------------------ // Compress a middle chunk // ------------------------------------------------------------------ compress.put_FirstChunk(false); compress.put_LastChunk(false); bdIn.Clear(); bdIn.AppendString(part2,"utf-8"); success = compress.CompressBd2(bdIn,bdOut); if (success == false) { std::cout << compress.lastErrorText() << "\r\n"; return; } // ------------------------------------------------------------------ // Compress the final chunk // ------------------------------------------------------------------ compress.put_FirstChunk(false); compress.put_LastChunk(true); bdIn.Clear(); bdIn.AppendString(part3,"utf-8"); success = compress.CompressBd2(bdIn,bdOut); if (success == false) { std::cout << compress.lastErrorText() << "\r\n"; return; } // Get the final compressed result as base64 for display const char *compressedBase64 = bdOut.getEncoded("base64"); std::cout << "Compressed data (base64):" << "\r\n"; std::cout << compressedBase64 << "\r\n"; // ------------------------------------------------------------------ // Decompress to verify correctness // ------------------------------------------------------------------ CkBinData bdDecompressed; compress.put_FirstChunk(true); compress.put_LastChunk(true); success = compress.DecompressBd2(bdOut,bdDecompressed); if (success == false) { std::cout << compress.lastErrorText() << "\r\n"; return; } // Convert decompressed bytes back to a string const char *resultText = bdDecompressed.getString("utf-8"); std::cout << "Decompressed text:" << "\r\n"; std::cout << resultText << "\r\n"; } |
||||||
© 2000-2026 Chilkat Software, Inc. All Rights Reserved.