PeakAlloc

Struct PeakAlloc 

Source
pub struct PeakAlloc;
Expand description

This structure implements a dead simple low-overhead wrapper around the system allocator. It lets a program know its own memory and peak memory consumption at runtime.

§Note

The peak allocator is really just a shim around the system allocator. The bulk of its work is delegated to the system allocator and all PeakAlloc does is to maintain the atomic counters.

§Example

To make use of the PeakAllocator, all you need to do, is to declare a static instance of it, and annotate it with the #[global_allocator] attribute. Then, in your main module (or anywhere else in your code where it is deemed useful), you just call methods on the static variable you declared.

use peak_alloc::PeakAlloc;

#[global_allocator]
static PEAK_ALLOC: PeakAlloc = PeakAlloc;

fn main() {
    // Do your funky stuff...

    let current_mem = PEAK_ALLOC.current_usage_as_mb();
    println!("This program currently uses {} MB of RAM.", current_mem);
    let peak_mem = PEAK_ALLOC.peak_usage_as_gb();
    println!("The max amount that was used {}", peak_mem);
}

Implementations§

Source§

impl PeakAlloc

Source

pub fn current_usage(&self) -> usize

Returns the number of bytes that are currently allocated to the process

Source

pub fn peak_usage(&self) -> usize

Returns the maximum number of bytes that have been allocated to the process over the course of its life.

Source

pub fn current_usage_as_kb(&self) -> f32

Returns the amount of memory (in kb) that is currently allocated to the process.

Source

pub fn current_usage_as_mb(&self) -> f32

Returns the amount of memory (in mb) that is currently allocated to the process.

Source

pub fn current_usage_as_gb(&self) -> f32

Returns the amount of memory (in gb) that is currently allocated to the process.

Source

pub fn peak_usage_as_kb(&self) -> f32

Returns the maximum quantity of memory (in kb) that have been allocated to the process over the course of its life.

Source

pub fn peak_usage_as_mb(&self) -> f32

Returns the maximum quantity of memory (in mb) that have been allocated to the process over the course of its life.

Source

pub fn peak_usage_as_gb(&self) -> f32

Returns the maximum quantity of memory (in gb) that have been allocated to the process over the course of its life.

Source

pub fn reset_peak_usage(&self)

Resets the peak usage to the value currently in memory

Trait Implementations§

Source§

impl Clone for PeakAlloc

Source§

fn clone(&self) -> PeakAlloc

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for PeakAlloc

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for PeakAlloc

Source§

fn default() -> PeakAlloc

Returns the “default value” for a type. Read more
Source§

impl GlobalAlloc for PeakAlloc

PeakAlloc only implements the minimum required set of methods to make it useable as a global allocator (with #[global_allocator] attribute).

No funky stuff is done below.

Source§

unsafe fn alloc(&self, layout: Layout) -> *mut u8

Allocates memory as described by the given layout. Read more
Source§

unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout)

Deallocates the block of memory at the given ptr pointer with the given layout. Read more
Source§

unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8

Behaves like alloc, but also ensures that the contents are set to zero before being returned. Read more
Source§

unsafe fn realloc( &self, ptr: *mut u8, layout: Layout, new_size: usize, ) -> *mut u8

Shrinks or grows a block of memory to the given new_size in bytes. The block is described by the given ptr pointer and layout. Read more
Source§

impl Copy for PeakAlloc

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.