#single-threaded

alloc-from-pool

Single-threaded object pool implementation

6 stable releases

1.0.5 Mar 28, 2024
1.0.4 Nov 7, 2021
1.0.3 Nov 4, 2021

#6 in #single-threaded

Download history 934/week @ 2024-07-22 765/week @ 2024-07-29 782/week @ 2024-08-05 1100/week @ 2024-08-12 1100/week @ 2024-08-19 1284/week @ 2024-08-26 646/week @ 2024-09-02 679/week @ 2024-09-09 722/week @ 2024-09-16 865/week @ 2024-09-23 869/week @ 2024-09-30 811/week @ 2024-10-07 946/week @ 2024-10-14 713/week @ 2024-10-21 850/week @ 2024-10-28 1006/week @ 2024-11-04

3,533 downloads per month
Used in 7 crates (via lib-ruby-parser)

MIT license

9KB
245 lines

alloc-from-pool

This crate implements object pool.

Basic usage

use alloc_from_pool::Pool;

// dummy struct
struct Foo([u8; 50]);

// pool has size = 0 by default
let pool = Pool::<Foo>::new();

// performs allocation
let foo1 = pool.alloc(Foo([1; 50]));
// returns memory back to pool
drop(foo1);

// re-uses the value that we've just returned back to pool
let foo2 = pool.alloc(Foo([2; 50]));
// returns memory back to pool
drop(foo2);

// it also possible to create a Factory based on a pool
// that holds a reference to initial Pool
let factory = pool.factory();
// Factory has the same `alloc` method:
let foo3 = factory.alloc(Foo([3; 50]));
// it uses the same pool, and also returns back to the same pool
drop(foo3);

Benchmarks

You can run cargo bench:

test alloc_with_box  ... bench:          56 ns/iter (+/- 6)
test alloc_with_pool ... bench:           7 ns/iter (+/- 0)

No runtime deps