| Crates.io | interloc |
| lib.rs | interloc |
| version | 0.1.3 |
| created_at | 2019-05-13 05:30:18.797705+00 |
| updated_at | 2021-02-05 05:34:35.388939+00 |
| description | Middleware allocator for keeping track of memory usage. |
| homepage | https://github.com/A1Liu/interloc |
| repository | https://github.com/A1Liu/interloc |
| max_upload_size | |
| id | 133938 |
| size | 13,825 |
interlocThis crate defines an interface for creating allocator middleware, i.e. code that runs when your allocator is run.
use interloc::{AllocMonitor, AllocAction, InterAlloc, StatsMonitor, ThreadMonitor};
use std::alloc::System;
use core::alloc::Layout;
struct MyMonitor {
pub global: StatsMonitor,
pub local: ThreadMonitor
}
impl MyMonitor {
// This needs to be const to be usable in static variable declarations.
pub const fn new() -> Self {
Self {
global: StatsMonitor::new(),
local: ThreadMonitor::new(),
}
}
}
impl AllocMonitor for MyMonitor {
// The immutable `&self` reference signature is there because the global allocator
// needs to be thread-safe.
fn monitor(&self, layout: Layout, action: AllocAction) {
// Monitors are inherently composable
self.global.monitor(layout, action);
self.local.monitor(layout, action);
}
}
static MONITOR: MyMonitor = MyMonitor::new();
// This needs to be done at the project root, i.e. `lib.rs` or `main.rs`
#[global_allocator]
static GLOBAL: InterAlloc<System, MyMonitor> = InterAlloc {
inner: System,
monitor: &MONITOR,
};