#memory #memory-pool #data #no-std

no-std membank

A pool of reusable memory to prevent unnecessary deallocations

7 releases (4 breaking)

0.5.1 Dec 5, 2023
0.5.0 Dec 5, 2023
0.4.1 Dec 4, 2023
0.3.0 Nov 26, 2023
0.1.0 Oct 19, 2023

#373 in Memory management

Download history 4/week @ 2024-07-24 13/week @ 2024-09-18 20/week @ 2024-09-25

52 downloads per month

MIT/Apache

12KB
224 lines

membank

The membank crate allows users to re-use memory for later instead of de-allocating it. This is great for large, heap-allocated data.

use membank::MemoryBank;

fn main() {
	let bank: MemoryBank<Vec<i32>> = MemoryBank::new();

	let mut big_dumb_vec = Vec::from_iter(0..10000);

	// First loan is always a new allocation
	let mut loan = bank.take_loan();
	loan.clone_from(&big_dumb_vec);

	assert_eq!(*loan, big_dumb_vec);

	// The memory in the loan is mutable
	loan[9990] = 14;

	big_dumb_vec[9990] = 14;
	assert_eq!(*loan, big_dumb_vec);

	// The loaned memory is returned to the bank
	drop(loan);

	// The bank reuses memory whenever it can
	let same_memory = bank.take_old_loan().unwrap();
	assert_eq!(*same_memory, big_dumb_vec);

	// The same bank can also be shared between threads!
	let bank_clone = bank.clone();
	std::thread::spawn(move || {
		assert_eq!(*bank.take_loan(), big_dumb_vec);
	});
}

Dependencies

~345KB