#object-pool #pool #async-pool #async #synchronization-primitive

dev async-object-pool

A simple object pool implementation that uses asynchronous synchronization primitives only

7 releases

0.1.4 Jan 7, 2021
0.1.3 Nov 14, 2020
0.1.2 Nov 14, 2020
0.1.1 Nov 14, 2020
0.1.0 Nov 14, 2020

#542 in Asynchronous

Download history 21710/week @ 2023-11-26 19594/week @ 2023-12-03 19874/week @ 2023-12-10 19134/week @ 2023-12-17 8577/week @ 2023-12-24 17769/week @ 2023-12-31 23938/week @ 2024-01-07 23650/week @ 2024-01-14 25730/week @ 2024-01-21 23811/week @ 2024-01-28 22999/week @ 2024-02-04 25306/week @ 2024-02-11 26386/week @ 2024-02-18 26759/week @ 2024-02-25 24384/week @ 2024-03-03 10927/week @ 2024-03-10

89,720 downloads per month
Used in 123 crates (2 directly)

MIT license

6KB

async-object-pool

A simple object pool implementation that uses asynchronous synchronization primitives only.

You can use it as follows:

use async_object_pool::Pool;

// Create a new pool that will allow to create at most 100 items
let pool = Pool::new(100);

// Take an item from the pool or create a new item if the pool is empty
// but the maximum number of pooled items was not created yet.
// This will asynchronously block execution until an item can be returned.
let item = pool.take_or_create(|| String::from("hello")).await;

// Use your item
println!("{}", item);

// After using the item, put it back into the pool so it can be reused elsewhere
pool.put(item).await;

This crate is used to pool HTTP mock servers in httpmock.

License

async-object-pool is free software: you can redistribute it and/or modify it under the terms of the MIT Public License.

This program 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 MIT Public License for more details.

Dependencies

~5–16MB
~186K SLoC