Struct rb_sys::tracking_allocator::TrackingAllocator

source ·
pub struct TrackingAllocator;
Expand description

A simple wrapper over std::alloc::System which reports memory usage to the Ruby GC. This gives the GC a more accurate picture of the process’ memory usage so it can make better decisions about when to run.

Implementations§

source§

impl TrackingAllocator

source

pub const fn new() -> Self

Create a new TrackingAllocator.

source

pub const fn default() -> Self

Create a new TrackingAllocator with default values.

source

pub fn adjust_memory_usage(delta: isize) -> isize

Adjust the memory usage reported to the Ruby GC by delta. Useful for tracking allocations invisible to the Rust allocator, such as mmap or direct malloc calls.

§Example
use rb_sys::TrackingAllocator;

// Allocate 1024 bytes of memory using `mmap` or `malloc`...
TrackingAllocator::adjust_memory_usage(1024);

// ...and then after the memory is freed, adjust the memory usage again.
TrackingAllocator::adjust_memory_usage(-1024);

Trait Implementations§

source§

impl Debug for TrackingAllocator

source§

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

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

impl GlobalAlloc for TrackingAllocator

source§

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

Allocate memory as described by 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 dealloc(&self, ptr: *mut u8, layout: Layout)

Deallocate the block of memory at the given ptr pointer with the given layout. Read more
source§

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

Shrink or grow a block of memory to the given new_size in bytes. The block is described by the given ptr pointer and layout. Read more

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> 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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.