| Crates.io | async-object-pool |
| lib.rs | async-object-pool |
| version | 0.2.0 |
| created_at | 2020-11-14 10:27:24.543471+00 |
| updated_at | 2025-08-27 21:25:55.142159+00 |
| description | A simple object pool implementation that uses asynchronous synchronization primitives only. |
| homepage | |
| repository | https://github.com/alexliesenfeld/async-object-pool |
| max_upload_size | |
| id | 312304 |
| size | 16,228 |
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.
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.