#async-task #thread-pool #async #blocking

async-cpupool

A simple async threadpool for CPU-bound tasks

5 unstable releases

0.3.0 Jul 9, 2024
0.2.2 Apr 15, 2024
0.2.1 Feb 12, 2024
0.2.0 Jan 7, 2024
0.1.0 Nov 26, 2023

#436 in Concurrency

32 downloads per month
Used in ap-relay

GPL-3.0 license

37KB
979 lines

Async CPUPool

A simple async threadpool for CPU-bound tasks

Usage

Add to your Cargo.toml

$ cargo add async-cpupool

Use in your application

fn complex_computation() {}

fn main() -> Result<(), Box<dyn std::error::Error>> {
    smol::block_on(async {
        let pool = async_cpupool::CpuPool::new();

        pool.spawn(move || {
            complex_computation();
        }).await?;

        pool.close().await;

        Ok(())
    })
}

Contributing

Feel free to open issues for anything you find an issue with. Please note that any contributed code will be licensed under the GPLv3.

License

Copyright © 2023 asonix

Async CPUPool is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

Async CPUPool is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. This file is part of Async CPUPool.

You should have received a copy of the GNU General Public License along with Async CPUPool. If not, see http://www.gnu.org/licenses/.

Dependencies

~1–25MB
~355K SLoC