#zip-archive #rayon #thread-pool #directory #file

rayonzip

使用rayon进行并发压缩来创建zip存档

2个不稳定版本

0.2.1 2023年2月2日
0.2.0 2023年2月2日
0.1.0 2023年2月1日

#526 in 压缩

MIT许可证

12KB
204 代码行

rayonzip

一个使用rayon进行线程控制的创建zip文件的库

该库受mtzip的启发,它自行管理并发。

示例用法

use rayon::ThreadPoolBuilder;
use rayonzip::ZipArchive;

// Get amount of available threads for use
let threads = std::threads::available_parallelism.unwrap();

// Build a rayon thread pool
let thread_pool = ThreadPoolBuilder::new().num_thread(threads.into()).build().unwrap();

// Create a zp archive that'll use the thread pool to compress concurrently
let mut zipper = ZipArchive::new(&thread_pool);

// Add a file from filesystem
zipper.add_file_from_fs("input/test_text_file.txt", "test_text_file.txt");

// Add a file from binary slice
zipper.add_file_from_slice(b"Hello, world!", "hello_world.txt");

// Adding a directory and a file to it
zipper.add_directory("test_dir");
zipper.add_file("input/file_that_goes_to_a_dir.txt", "test_dir/file_that_goes_to_a_dir.txt");

// Writing to a file

// First, open/create a file
let mut file = File::create("output.zip").unwrap();
// Now, write the zip archive data to a file.
// This consumes the zip archive struct. Write to a buffer if you want to write to multiple destinations
zipper.write(&mut file).unwrap();

依赖项

~1.5MB
~31K SLoC