Struct DefaultAlloc

Source
pub struct DefaultAlloc;
Expand description

Default allocator, delegating to the global allocator.

Trait Implementations§

Source§

impl Alloc for DefaultAlloc

Source§

fn alloc(&self, layout: Layout) -> Result<NonNull<u8>, AllocError>

Attempts to allocate a block of memory fitting the given Layout. Read more
Source§

fn alloc_zeroed(&self, layout: Layout) -> Result<NonNull<u8>, AllocError>

Attempts to allocate a zeroed block of memory fitting the given Layout. Read more
Source§

fn alloc_filled(&self, layout: Layout, n: u8) -> Result<NonNull<u8>, AllocError>

Attempts to allocate a block of memory fitting the given Layout, filled with bytes initialized to n. Read more
Source§

fn alloc_patterned<F: Fn(usize) -> u8>( &self, layout: Layout, pattern: F, ) -> Result<NonNull<u8>, AllocError>

Attempts to allocate a block of memory fitting the given Layout and fill it by calling pattern(i) for each byte index i. Read more
Source§

unsafe fn dealloc(&self, ptr: NonNull<u8>, layout: Layout)

Deallocates a previously allocated block. Read more
Source§

fn alloc_slice<T>(&self, len: usize) -> Result<NonNull<[T]>, AllocError>

Attempts to allocate a block of memory for len instances of T. Read more
Source§

fn alloc_slice_zeroed<T>(&self, len: usize) -> Result<NonNull<[T]>, AllocError>

Attempts to allocate a zeroed block of memory for len instances of T. Read more
Source§

fn alloc_slice_filled<T>( &self, len: usize, n: u8, ) -> Result<NonNull<[T]>, AllocError>

Attempts to allocate a block of memory for len instances of T, filled with bytes initialized to n. Read more
Source§

fn alloc_slice_patterned<T, F: Fn(usize) -> u8>( &self, len: usize, pattern: F, ) -> Result<NonNull<[T]>, AllocError>

Attempts to allocate a block of memory for len instances of T and fill it by calling pattern(i) for each byte index i. Read more
Source§

unsafe fn dealloc_n<T>(&self, ptr: NonNull<T>, n: usize)

Deallocates a previously allocated block. Read more
Source§

unsafe fn drop_and_dealloc<T: ?Sized>(&self, ptr: NonNull<T>)

Drops the data at a pointer and deallocates its previously allocated block. Read more
Source§

unsafe fn drop_and_dealloc_n<T>(&self, ptr: NonNull<T>, n: usize)

Drops the data at a pointer and deallocates its previously allocated block. Read more
Source§

unsafe fn grow( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<u8>, AllocError>

Grow the given block to a new, larger layout. Read more
Source§

unsafe fn grow_zeroed( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<u8>, AllocError>

Grows the given block to a new, larger layout, zeroing newly allocated space. Read more
Source§

unsafe fn grow_patterned<F: Fn(usize) -> u8>( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, pattern: F, ) -> Result<NonNull<u8>, AllocError>

Grow the given block to a new, larger layout, filling any newly allocated bytes by calling pattern(i) for each new byte index i. Read more
Source§

fn grow_filled( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, n: u8, ) -> Result<NonNull<u8>, AllocError>

Grows the given block to a new, larger layout, filling newly allocated space with n. Read more
Source§

unsafe fn shrink( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<u8>, AllocError>

Shrink the given block to a new, smaller layout. Read more
Source§

unsafe fn realloc( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<u8>, AllocError>

Reallocate a block, growing or shrinking as needed (no zeroing). Read more
Source§

unsafe fn realloc_zeroed( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<u8>, AllocError>

Reallocate a block, growing or shrinking as needed, zeroing any newly allocated bytes. Read more
Source§

unsafe fn realloc_patterned<F: Fn(usize) -> u8>( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, pattern: F, ) -> Result<NonNull<u8>, AllocError>

Reallocate a block, growing or shrinking as needed, filling any new bytes by calling pattern(i) for each new byte index i. Read more
Source§

unsafe fn realloc_filled( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, n: u8, ) -> Result<NonNull<u8>, AllocError>

Reallocate a block, growing or shrinking as needed, filling any newly allocated bytes with n. Read more
Source§

impl Allocator for DefaultAlloc

Source§

fn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>

🔬This is a nightly-only experimental API. (allocator_api)
Attempts to allocate a block of memory. Read more
Source§

fn allocate_zeroed(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>

🔬This is a nightly-only experimental API. (allocator_api)
Behaves like allocate, but also ensures that the returned memory is zero-initialized. Read more
Source§

unsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout)

🔬This is a nightly-only experimental API. (allocator_api)
Deallocates the memory referenced by ptr. Read more
Source§

unsafe fn grow( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

🔬This is a nightly-only experimental API. (allocator_api)
Attempts to extend the memory block. Read more
Source§

unsafe fn grow_zeroed( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

🔬This is a nightly-only experimental API. (allocator_api)
Behaves like grow, but also ensures that the new contents are set to zero before being returned. Read more
Source§

unsafe fn shrink( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

🔬This is a nightly-only experimental API. (allocator_api)
Attempts to shrink the memory block. Read more
Source§

fn by_ref(&self) -> &Self
where Self: Sized,

🔬This is a nightly-only experimental API. (allocator_api)
Creates a “by reference” adapter for this instance of Allocator. Read more
Source§

impl Clone for DefaultAlloc

Source§

fn clone(&self) -> DefaultAlloc

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 Debug for DefaultAlloc

Source§

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

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

impl Default for DefaultAlloc

Source§

fn default() -> DefaultAlloc

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

impl GlobalAlloc for DefaultAlloc

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 Hash for DefaultAlloc

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for DefaultAlloc

Source§

fn cmp(&self, other: &DefaultAlloc) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for DefaultAlloc

Source§

fn eq(&self, other: &DefaultAlloc) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for DefaultAlloc

Source§

fn partial_cmp(&self, other: &DefaultAlloc) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Copy for DefaultAlloc

Source§

impl Eq for DefaultAlloc

Source§

impl StructuralPartialEq for DefaultAlloc

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<A> AllocExt for A
where A: Alloc,

Source§

fn alloc_init<T, I: Fn(NonNull<T>)>( &self, init: I, ) -> Result<NonNull<T>, AllocError>

Allocates uninitialized memory for a single T and initializes it using init. Read more
Source§

fn alloc_init_slice<T, I: Fn(NonNull<[T]>)>( &self, init: I, len: usize, ) -> Result<NonNull<[T]>, AllocError>

Allocates uninitialized memory for a [T] of length len and initializes it using init. Read more
Source§

fn alloc_default<T: Default>(&self) -> Result<NonNull<T>, AllocError>

Allocates uninitialized memory for a single T and writes T’s default into it. Read more
Source§

fn alloc_default_slice<T: Default>( &self, len: usize, ) -> Result<NonNull<[T]>, AllocError>

Allocates uninitialized memory for a [T] of length len and fills each element with T’s default value. Read more
Source§

fn alloc_write<T>(&self, data: T) -> Result<NonNull<T>, AllocError>

Allocates uninitialized memory for a single T and writes data into it. Read more
Source§

fn alloc_clone_to<T: CloneToUninit + ?Sized>( &self, data: &T, ) -> Result<NonNull<T>, AllocError>

Allocates uninitialized memory for a single T and clones data into it. Read more
Source§

fn alloc_clone_slice_to<T: Clone>( &self, data: &[T], ) -> Result<NonNull<[T]>, AllocError>

Allocates uninitialized memory for a slice of T and clones each element. Read more
Source§

fn alloc_slice_with<T, F: Fn(usize) -> T>( &self, len: usize, f: F, ) -> Result<NonNull<[T]>, AllocError>

Allocates uninitialized memory for a [T] of length len and fills each element with the result of f(elem_idx). Read more
Source§

unsafe fn grow_slice<T>( &self, ptr: NonNull<[T]>, new_len: usize, ) -> Result<NonNull<[T]>, AllocError>

Grows a slice to a new length. Read more
Source§

unsafe fn grow_raw_slice<T>( &self, ptr: NonNull<T>, len: usize, new_len: usize, ) -> Result<NonNull<[T]>, AllocError>

Grows a slice to a new length given the pointer to its first element, current length, and requested length. Read more
Source§

unsafe fn zero_and_dealloc(&self, ptr: NonNull<u8>, layout: Layout)

Zeroes and deallocates the memory at a pointer. Read more
Source§

unsafe fn dealloc_typed<T: ?Sized>(&self, ptr: NonNull<T>)

Deallocates a pointer’s memory. Read more
Source§

unsafe fn zero_and_dealloc_typed<T: ?Sized>(&self, ptr: NonNull<T>)

Zeroes and deallocates the memory at a pointer. Read more
Source§

unsafe fn dealloc_slice<T>(&self, slice_ptr: NonNull<[T]>)

Deallocates a previously cloned or written slice of T. Read more
Source§

unsafe fn drop_and_dealloc_slice<T>(&self, slice_ptr: NonNull<[T]>)

Drops and deallocates a previously cloned or written slice of T. Read more
Source§

unsafe fn drop_zero_and_dealloc<T: ?Sized>(&self, ptr: NonNull<T>)

Drops the value at the given pointer, then zeroes and deallocates its memory. Read more
Source§

fn alloc_copy_ref_to<T: ?Sized + UnsizedCopy>( &self, data: &T, ) -> Result<NonNull<T>, AllocError>

Allocates and copies an unsized T by reference, returning a NonNull<T>. Read more
Source§

unsafe fn alloc_copy_ptr_to<T: ?Sized + UnsizedCopy>( &self, data: *const T, ) -> Result<NonNull<T>, AllocError>

Allocates and copies an unsized T by raw pointer, returning a NonNull<T>. Read more
Source§

unsafe fn alloc_copy_ref_to_unchecked<T: ?Sized>( &self, data: &T, ) -> Result<NonNull<T>, AllocError>

Allocates and copies an unsized T by reference without requiring T: UnsizedCopy, returning a NonNull<T>. Read more
Source§

unsafe fn alloc_copy_ptr_to_unchecked<T: ?Sized + UnsizedCopy>( &self, data: *const T, ) -> Result<NonNull<T>, AllocError>

Allocates and copies an unsized T by raw pointer without requiring T: UnsizedCopy, returning a NonNull<T>. Read more
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> SizedProps for T

Source§

const SZ: usize = _

The size of the type.
Source§

const ALIGN: usize = _

The alignment of the type.
Source§

const LAYOUT: Layout = _

The memory layout for the type.
Source§

const IS_ZST: bool = _

Whether the type is zero-sized.
Source§

const MAX_SLICE_LEN: usize = _

The largest safe length for a [Self].
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.
Source§

impl<P> Thin for P
where P: Pointee<Metadata = ()>,

Source§

impl<T> UnsizedCopy for T
where T: Copy,