3 unstable releases
0.2.1 | Oct 14, 2021 |
---|---|
0.2.0 | Oct 13, 2021 |
0.1.0 | Oct 12, 2021 |
#406 in Memory management
9KB
104 lines
async-alloc-counter measures max allocations in a future invocation
see examples/
for usage
This allocator can be used as follows:
use async_alloc_counter::*;
use futures::FutureExt;
use std::{alloc::System, time::Duration};
// set up the counting allocator
#[global_allocator]
static GLOBAL: AsyncAllocatorCounter<System> = AsyncAllocatorCounter { allocator: System };
#[tokio::main]
async fn main() {
async move {
let mut v: Vec<u8> = Vec::with_capacity(1024);
}.count_allocations()
.map(move |(max, ())| {
println!("future allocated {} max bytes", max);
})
.await
}
Allocation measurement can be stacked:
async move {
println!("wrapping future");
tokio::time::sleep(std::timeDuration::from_secs(1)).await;
let mut v: Vec<u8> = Vec::with_capacity(256);
async move {
let mut v: Vec<u8> = Vec::with_capacity(1024);
}.count_allocations()
.map(move |(max, ())| {
println!("future allocated {} max bytes", max);
})
.await
}.count_allocations()
.map(move |(max, ())| {
println!("warpping future allocated {} max bytes", max);
})
.await
Design inspired by the excellent tracing crate
Dependencies
~47KB