6 releases (breaking)

Uses old Rust 2015

0.5.0 Jan 28, 2020
0.4.0 Jun 22, 2018
0.3.1 May 16, 2018
0.2.0 May 8, 2018
0.1.0 May 3, 2018

#548 in Memory management

34 downloads per month
Used in hyper-client-pool

MIT license

12KB
217 lines

fpool

Non-leased object-pooling in Rust.

Non-leased as in: you cannot hold onto objects given from the Pool. This, unfortunately, is not something I could get enforced by the compiler without making the API hard to work with.

Getting started

Add the following to your Cargo.toml file:

[dependencies]
fpool = "0.3"

Next, add this to your crate:

extern crate fpool;

Examples

A trivial use-case for a round-robin pool:

use fpool::RoundRobinPool;

let mut pool = RoundRobinPool::builder(5, || -> Result<_, ()> {
    Ok(Vec::new())
}).build().expect("No constructor failure case");

for index in 0..10 {
 let list = pool.get().expect("No constructor failure case");
 list.push(index);
}

// The pool now has 5 lists with 2 items each
for _ in 0..5 {
 let list = pool.get().expect("No constructor failure case");
 assert_eq!(list.len(), 2);
}

But a more useful and realistic example is a thread-pool, see examples/thread_pool.rs.

No runtime deps