Struct rb_sys::tracking_allocator::ManuallyTracked

source ·
pub struct ManuallyTracked<T> { /* private fields */ }
Expand description

A guard which adjusts the memory usage reported to the Ruby GC by delta. This allows you to track resources which are invisible to the Rust allocator, such as items that are known to internally use mmap or direct malloc in their implementation.

Internally, it uses an Arc<AtomicIsize> to track the memory usage delta, and is safe to clone when T is Clone.

§Example

use rb_sys::tracking_allocator::ManuallyTracked;

type SomethingThatUsedMmap = ();

// Will tell the Ruby GC that 1024 bytes were allocated.
let item = ManuallyTracked::new(SomethingThatUsedMmap, 1024);

// Will tell the Ruby GC that 1024 bytes were freed.
std::mem::drop(item);

Implementations§

source§

impl<T> ManuallyTracked<T>

source

pub fn wrap(item: T, memsize: usize) -> Self

Create a new ManuallyTracked<T>, and immediately report that memsize bytes were allocated.

source

pub fn increase_memory_usage(&self, memsize: usize)

Increase the memory usage reported to the Ruby GC by memsize bytes.

source

pub fn decrease_memory_usage(&self, memsize: usize)

Decrease the memory usage reported to the Ruby GC by memsize bytes.

source

pub fn memsize_delta(&self) -> isize

Get the current memory usage delta.

source

pub fn get(&self) -> &T

Get a shared reference to the inner T.

source

pub fn get_mut(&mut self) -> &mut T

Get a mutable reference to the inner T.

source§

impl ManuallyTracked<()>

source

pub fn new(memsize: usize) -> Self

Create a new ManuallyTracked<()>, and immediately report that memsize bytes were allocated.

Trait Implementations§

source§

impl<T: Clone> Clone for ManuallyTracked<T>

source§

fn clone(&self) -> Self

Returns a copy 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<T: Debug> Debug for ManuallyTracked<T>

source§

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

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

impl Default for ManuallyTracked<()>

source§

fn default() -> Self

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

Auto Trait Implementations§

§

impl<T> Freeze for ManuallyTracked<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for ManuallyTracked<T>
where T: RefUnwindSafe,

§

impl<T> Send for ManuallyTracked<T>
where T: Send,

§

impl<T> Sync for ManuallyTracked<T>
where T: Sync,

§

impl<T> Unpin for ManuallyTracked<T>
where T: Unpin,

§

impl<T> UnwindSafe for ManuallyTracked<T>
where T: UnwindSafe,

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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,

§

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

§

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.