--- /srv/reproducible-results/rbuild-debian/r-b-build.ZF97ctvn/b1/rustc_1.83.0+dfsg1-1_amd64.changes +++ /srv/reproducible-results/rbuild-debian/r-b-build.ZF97ctvn/b2/rustc_1.83.0+dfsg1-1_amd64.changes ├── Files │ @@ -1,20 +1,20 @@ │ │ c29c778ed91bd3f4fa632e0e74f0507a 72090168 debug optional cargo-dbgsym_1.83.0+dfsg1-1_amd64.deb │ - 4b6983a1811ce0151ba1aa655dd733b3 4309128 doc optional cargo-doc_1.83.0+dfsg1-1_all.deb │ + 64b652610b06ccec3a747897f6c1b204 4309348 doc optional cargo-doc_1.83.0+dfsg1-1_all.deb │ f3faa0815b723aacebe9a4300381a43c 6208016 devel optional cargo_1.83.0+dfsg1-1_amd64.deb │ 93ca23253f0e08278b46c4b418461ceb 265907436 debug optional libstd-rust-1.83-dbgsym_1.83.0+dfsg1-1_amd64.deb │ b7d0ae05bc5885d32cc9f22710d9b720 19396008 libs optional libstd-rust-1.83_1.83.0+dfsg1-1_amd64.deb │ 83ec025906fb5073052c1ac8ad2147d5 121124628 libdevel optional libstd-rust-dev-wasm32_1.83.0+dfsg1-1_all.deb │ - c9c272d9c4aea73a9e0f15c0669d8e5e 43617732 libdevel optional libstd-rust-dev-windows_1.83.0+dfsg1-1_amd64.deb │ + 1540d0250a1bd5eb380e5a94259784fb 43622568 libdevel optional libstd-rust-dev-windows_1.83.0+dfsg1-1_amd64.deb │ 5682dbca6a973c6bef4f9e907d071859 38654988 libdevel optional libstd-rust-dev_1.83.0+dfsg1-1_amd64.deb │ 1c03bfc5ddee21984d2424b4a499a192 237312 devel optional rust-all_1.83.0+dfsg1-1_all.deb │ 3dd7b9f3c5a33809baa28b975715354c 59965336 debug optional rust-clippy-dbgsym_1.83.0+dfsg1-1_amd64.deb │ a3762440ac21cab13df59e4e5ebc9a78 3297264 devel optional rust-clippy_1.83.0+dfsg1-1_amd64.deb │ - dec7be8f582aaf74e5cd59441909aef4 22223036 doc optional rust-doc_1.83.0+dfsg1-1_all.deb │ + 49a772ebdfa678286ef4fe8409742d42 22073860 doc optional rust-doc_1.83.0+dfsg1-1_all.deb │ 60e3968ef3498034bc3f64056a8a7294 243016 devel optional rust-gdb_1.83.0+dfsg1-1_all.deb │ 11fb39af30be7dbad349585a186313bc 243768 devel optional rust-lldb_1.83.0+dfsg1-1_all.deb │ f3fc176b7109b9a419b055a26c1a9c7f 1712880 devel optional rust-llvm_1.83.0+dfsg1-1_amd64.deb │ ee5a3aed8c19a06659b4af89c954988a 46522292 devel optional rust-src_1.83.0+dfsg1-1_all.deb │ 67f763d52d2585df3af4250d41049c82 36425672 debug optional rustc-dbgsym_1.83.0+dfsg1-1_amd64.deb │ 3dbe75ac6c875230849f6519325b75d0 3767164 devel optional rustc_1.83.0+dfsg1-1_amd64.deb │ 089bb35fc6cb9b9b98c5e64ab1bb7144 24135700 debug optional rustfmt-dbgsym_1.83.0+dfsg1-1_amd64.deb ├── cargo-doc_1.83.0+dfsg1-1_all.deb │ ├── file list │ │ @@ -1,3 +1,3 @@ │ │ -rw-r--r-- 0 0 0 4 2024-12-04 17:07:54.000000 debian-binary │ │ --rw-r--r-- 0 0 0 74780 2024-12-04 17:07:54.000000 control.tar.xz │ │ --rw-r--r-- 0 0 0 4234156 2024-12-04 17:07:54.000000 data.tar.xz │ │ +-rw-r--r-- 0 0 0 74796 2024-12-04 17:07:54.000000 control.tar.xz │ │ +-rw-r--r-- 0 0 0 4234360 2024-12-04 17:07:54.000000 data.tar.xz │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./md5sums │ │ │ │ ├── ./md5sums │ │ │ │ │┄ Files differ │ ├── data.tar.xz │ │ ├── data.tar │ │ │ ├── file list │ │ │ │ @@ -2745,15 +2745,15 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 35914 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/struct.Registry.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22990 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/struct.TotalCrates.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 25438 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/struct.User.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22944 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/struct.Users.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 21933 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/struct.Warnings.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4964 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/crates_io/type.Result.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2991 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/help.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 3266 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/index.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 3273 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/index.html │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5349 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/all.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 28713 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/enum.Format.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4171 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/fn.convert.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3399 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/fn.extract_section.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3207 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/fn.join_url.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4043 2024-12-04 17:07:54.000000 ./usr/share/doc/cargo/reference/mdman/fn.md_parser.html │ │ │ ├── ./usr/share/doc/cargo/reference/index.html │ │ │ │ @@ -1,2 +1,2 @@ │ │ │ │ -
pub unsafe fn alloc(layout: Layout) -> *mut u8
Allocates memory with the global allocator.
│ │ │ │ +pub unsafe fn alloc(layout: Layout) -> *mut u8
Allocates memory with the global allocator.
│ │ │ │This function forwards calls to the GlobalAlloc::alloc
method
│ │ │ │ of the allocator registered with the #[global_allocator]
attribute
│ │ │ │ if there is one, or the std
crate’s default.
This function is expected to be deprecated in favor of the alloc
method
│ │ │ │ of the Global
type when it and the Allocator
trait become stable.
See GlobalAlloc::alloc
.
pub unsafe fn alloc_zeroed(layout: Layout) -> *mut u8
Allocates zero-initialized memory with the global allocator.
│ │ │ │ +pub unsafe fn alloc_zeroed(layout: Layout) -> *mut u8
Allocates zero-initialized memory with the global allocator.
│ │ │ │This function forwards calls to the GlobalAlloc::alloc_zeroed
method
│ │ │ │ of the allocator registered with the #[global_allocator]
attribute
│ │ │ │ if there is one, or the std
crate’s default.
This function is expected to be deprecated in favor of the alloc_zeroed
method
│ │ │ │ of the Global
type when it and the Allocator
trait become stable.
See GlobalAlloc::alloc_zeroed
.
pub unsafe fn dealloc(ptr: *mut u8, layout: Layout)
Deallocates memory with the global allocator.
│ │ │ │ +pub unsafe fn dealloc(ptr: *mut u8, layout: Layout)
Deallocates memory with the global allocator.
│ │ │ │This function forwards calls to the GlobalAlloc::dealloc
method
│ │ │ │ of the allocator registered with the #[global_allocator]
attribute
│ │ │ │ if there is one, or the std
crate’s default.
This function is expected to be deprecated in favor of the dealloc
method
│ │ │ │ of the Global
type when it and the Allocator
trait become stable.
See GlobalAlloc::dealloc
.
pub fn handle_alloc_error(layout: Layout) -> !
Signals a memory allocation error.
│ │ │ │ +pub fn handle_alloc_error(layout: Layout) -> !
Signals a memory allocation error.
│ │ │ │Callers of memory allocation APIs wishing to cease execution
│ │ │ │ in response to an allocation error are encouraged to call this function,
│ │ │ │ -rather than directly invoking panic!
or similar.
panic!
or similar.
│ │ │ │ This function is guaranteed to diverge (not return normally with a value), but depending on │ │ │ │ global configuration, it may either panic (resulting in unwinding or aborting as per │ │ │ │ configuration for all panics), or abort the process (with no unwinding).
│ │ │ │The default behavior is:
│ │ │ │If the binary links against std
(typically the case), then
│ │ │ │ print a message to standard error and abort the process.
│ │ │ │ This behavior can be replaced with set_alloc_error_hook
and take_alloc_error_hook
.
│ │ │ │ Future versions of Rust may panic by default instead.
If the binary does not link against std
(all of its crates are marked
│ │ │ │ -#![no_std]
), then call panic!
with a message.
│ │ │ │ +#![no_std]
), then call panic!
with a message.
│ │ │ │ The panic handler applies as to any panic.
pub unsafe fn realloc(ptr: *mut u8, layout: Layout, new_size: usize) -> *mut u8
Reallocates memory with the global allocator.
│ │ │ │ +pub unsafe fn realloc(ptr: *mut u8, layout: Layout, new_size: usize) -> *mut u8
Reallocates memory with the global allocator.
│ │ │ │This function forwards calls to the GlobalAlloc::realloc
method
│ │ │ │ of the allocator registered with the #[global_allocator]
attribute
│ │ │ │ if there is one, or the std
crate’s default.
This function is expected to be deprecated in favor of the realloc
method
│ │ │ │ of the Global
type when it and the Allocator
trait become stable.
See GlobalAlloc::realloc
.
pub struct AllocError;
allocator_api
#32838)The AllocError
error indicates an allocation failure
│ │ │ │ +
pub struct AllocError;
allocator_api
#32838)The AllocError
error indicates an allocation failure
│ │ │ │ that may be due to resource exhaustion or to
│ │ │ │ something wrong when combining the given input arguments with this
│ │ │ │ allocator.
source
. Read moresource
. Read morepub struct Global;
allocator_api
#32838)The global memory allocator.
│ │ │ │This type implements the Allocator
trait by forwarding calls
│ │ │ │ to the allocator registered with the #[global_allocator]
attribute
│ │ │ │ if there is one, or the std
crate’s default.
Note: while this type is unstable, the functionality it provides can be
│ │ │ │ accessed through the free functions in alloc
.
allocator_api
#32838)allocator_api
#32838)allocate
, but also ensures that the returned memory is zero-initialized. Read moreallocator_api
#32838)allocator_api
#32838)allocate
, but also ensures that the returned memory is zero-initialized. Read moreallocator_api
#32838)ptr
. Read moreallocator_api
#32838)allocator_api
#32838)allocator_api
#32838)grow
, but also ensures that the new contents are set to zero before being
│ │ │ │ +) -> Result<NonNull<[u8]>, AllocError>allocator_api
#32838)grow
, but also ensures that the new contents are set to zero before being
│ │ │ │ returned. Read moreallocator_api
#32838)pub struct Layout { /* private fields */ }
Layout of a block of memory.
│ │ │ │ +pub struct Layout { /* private fields */ }
Layout of a block of memory.
│ │ │ │An instance of Layout
describes a particular layout of memory.
│ │ │ │ You build a Layout
up as an input to give to an allocator.
All layouts have an associated size and a power-of-two alignment. The size, when rounded up to
│ │ │ │ the nearest multiple of align
, does not overflow isize
(i.e., the rounded value will always be
│ │ │ │ less than or equal to isize::MAX
).
(Note that layouts are not required to have non-zero size,
│ │ │ │ even though GlobalAlloc
requires that all memory requests
│ │ │ │ be non-zero in size. A caller must either ensure that conditions
│ │ │ │ like this are met, use specific allocators with looser
│ │ │ │ requirements, or use the more lenient Allocator
interface.)
Constructs a Layout
from a given size
and align
,
│ │ │ │ +
Constructs a Layout
from a given size
and align
,
│ │ │ │ or returns LayoutError
if any of the following conditions
│ │ │ │ are not met:
align
must not be zero,
size
, when rounded up to the nearest multiple of align
,
│ │ │ │ must not overflow isize
(i.e., the rounded value must be
│ │ │ │ less than or equal to isize::MAX
).
Creates a layout, bypassing all checks.
│ │ │ │This function is unsafe as it does not verify the preconditions from
│ │ │ │ Layout::from_size_align
.
The minimum size in bytes for a memory block of this layout.
│ │ │ │ -The minimum byte alignment for a memory block of this layout.
│ │ │ │ +The minimum size in bytes for a memory block of this layout.
│ │ │ │ +The minimum byte alignment for a memory block of this layout.
│ │ │ │The returned alignment is guaranteed to be a power of two.
│ │ │ │ -Constructs a Layout
suitable for holding a value of type T
.
Produces layout describing a record that could be used to │ │ │ │ +
Constructs a Layout
suitable for holding a value of type T
.
Produces layout describing a record that could be used to
│ │ │ │ allocate backing structure for T
(which could be a trait
│ │ │ │ or other unsized type like a slice).
layout_for_ptr
#69835)Produces layout describing a record that could be used to │ │ │ │ +
layout_for_ptr
#69835)Produces layout describing a record that could be used to
│ │ │ │ allocate backing structure for T
(which could be a trait
│ │ │ │ or other unsized type like a slice).
This function is only safe to call if the following conditions hold:
│ │ │ │T
is Sized
, this function is always safe to call.T
is:
│ │ │ │ isize
.
│ │ │ │ For the special case where the dynamic tail length is 0, this function
│ │ │ │ is safe to call.T
acquired by an unsizing coercion,
│ │ │ │ and the size of the entire value
│ │ │ │ @@ -66,48 +66,48 @@
│ │ │ │ call, but may panic or otherwise return the wrong value, as the
│ │ │ │ extern type’s layout is not known. This is the same behavior as
│ │ │ │ Layout::for_value
on a reference to an extern type tail.alloc_layout_extra
#55724)Creates a NonNull
that is dangling, but well-aligned for this Layout.
alloc_layout_extra
#55724)Creates a NonNull
that is dangling, but well-aligned for this Layout.
Note that the pointer value may potentially represent a valid pointer, │ │ │ │ which means this must not be used as a “not yet initialized” │ │ │ │ sentinel value. Types that lazily allocate must track initialization by │ │ │ │ some other means.
│ │ │ │ -Creates a layout describing the record that can hold a value │ │ │ │ +
Creates a layout describing the record that can hold a value
│ │ │ │ of the same layout as self
, but that also is aligned to
│ │ │ │ alignment align
(measured in bytes).
If self
already meets the prescribed alignment, then returns
│ │ │ │ self
.
Note that this method does not add any padding to the overall
│ │ │ │ size, regardless of whether the returned layout has a different
│ │ │ │ alignment. In other words, if K
has size 16, K.align_to(32)
│ │ │ │ will still have size 16.
Returns an error if the combination of self.size()
and the given
│ │ │ │ align
violates the conditions listed in Layout::from_size_align
.
alloc_layout_extra
#55724)Returns the amount of padding we must insert after self
│ │ │ │ +
alloc_layout_extra
#55724)Returns the amount of padding we must insert after self
│ │ │ │ to ensure that the following address will satisfy align
│ │ │ │ (measured in bytes).
e.g., if self.size()
is 9, then self.padding_needed_for(4)
│ │ │ │ returns 3, because that is the minimum number of bytes of
│ │ │ │ padding required to get a 4-aligned address (assuming that the
│ │ │ │ corresponding memory block starts at a 4-aligned address).
The return value of this function has no meaning if align
is
│ │ │ │ not a power-of-two.
Note that the utility of the returned value requires align
│ │ │ │ to be less than or equal to the alignment of the starting
│ │ │ │ address for the whole allocated block of memory. One way to
│ │ │ │ satisfy this constraint is to ensure align <= self.align()
.
Creates a layout by rounding the size of this layout up to a multiple │ │ │ │ +
Creates a layout by rounding the size of this layout up to a multiple │ │ │ │ of the layout’s alignment.
│ │ │ │This is equivalent to adding the result of padding_needed_for
│ │ │ │ to the layout’s current size.
alloc_layout_extra
#55724)Creates a layout describing the record for n
instances of
│ │ │ │ +
alloc_layout_extra
#55724)Creates a layout describing the record for n
instances of
│ │ │ │ self
, with a suitable amount of padding between each to
│ │ │ │ ensure that each instance is given its requested size and
│ │ │ │ alignment. On success, returns (k, offs)
where k
is the
│ │ │ │ layout of the array and offs
is the distance between the start
│ │ │ │ of each element in the array.
(That distance between elements is sometimes known as “stride”.)
│ │ │ │On arithmetic overflow, returns LayoutError
.
Creates a layout describing the record for self
followed by
│ │ │ │ +
Creates a layout describing the record for self
followed by
│ │ │ │ next
, including any necessary padding to ensure that next
│ │ │ │ will be properly aligned, but no trailing padding.
In order to match C representation layout repr(C)
, you should
│ │ │ │ call pad_to_align
after extending the layout with all fields.
│ │ │ │ (There is no way to match the default Rust representation
│ │ │ │ layout repr(Rust)
, as it is unspecified.)
Note that the alignment of the resulting layout will be the maximum of │ │ │ │ @@ -149,42 +149,42 @@ │ │ │ │ let (new_layout, offset) = layout.extend(field)?; │ │ │ │ layout = new_layout; │ │ │ │ offsets.push(offset); │ │ │ │ } │ │ │ │ // Remember to finalize with `pad_to_align`! │ │ │ │ Ok((layout.pad_to_align(), offsets)) │ │ │ │ }
alloc_layout_extra
#55724)Creates a layout describing the record for n
instances of
│ │ │ │ +
alloc_layout_extra
#55724)Creates a layout describing the record for n
instances of
│ │ │ │ self
, with no padding between each instance.
Note that, unlike repeat
, repeat_packed
does not guarantee
│ │ │ │ that the repeated instances of self
will be properly
│ │ │ │ aligned, even if a given instance of self
is properly
│ │ │ │ aligned. In other words, if the layout returned by
│ │ │ │ repeat_packed
is used to allocate an array, it is not
│ │ │ │ guaranteed that all elements in the array will be properly
│ │ │ │ aligned.
On arithmetic overflow, returns LayoutError
.
alloc_layout_extra
#55724)Creates a layout describing the record for self
followed by
│ │ │ │ +
alloc_layout_extra
#55724)Creates a layout describing the record for self
followed by
│ │ │ │ next
with no additional padding between the two. Since no
│ │ │ │ padding is inserted, the alignment of next
is irrelevant,
│ │ │ │ and is not incorporated at all into the resulting layout.
On arithmetic overflow, returns LayoutError
.
#[non_exhaustive]pub struct LayoutError;
The LayoutError
is returned when the parameters given
│ │ │ │ +
#[non_exhaustive]pub struct LayoutError;
The LayoutError
is returned when the parameters given
│ │ │ │ to Layout::from_size_align
│ │ │ │ or some other Layout
constructor
│ │ │ │ do not satisfy its documented constraints.
source
. Read moreAlways evaluates to TryReserveErrorKind::CapacityOverflow
.
source
. Read moreAlways evaluates to TryReserveErrorKind::CapacityOverflow
.
pub unsafe trait Allocator {
│ │ │ │ +Allocator in alloc::alloc - Rust pub unsafe trait Allocator {
│ │ │ │ // Required methods
│ │ │ │ - fn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>;
│ │ │ │ - unsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout);
│ │ │ │ + fn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>;
│ │ │ │ + unsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout);
│ │ │ │
│ │ │ │ // Provided methods
│ │ │ │ fn allocate_zeroed(
│ │ │ │ &self,
│ │ │ │ layout: Layout,
│ │ │ │ - ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ + ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ unsafe fn grow(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ - ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ + ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ unsafe fn grow_zeroed(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ - ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ + ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ unsafe fn shrink(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ - ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ + ) -> Result<NonNull<[u8]>, AllocError> { ... }
│ │ │ │ fn by_ref(&self) -> &Self
│ │ │ │ - where Self: Sized { ... }
│ │ │ │ + where Self: Sized { ... }
│ │ │ │ }
🔬This is a nightly-only experimental API. (allocator_api
#32838)Expand description
An implementation of Allocator
can allocate, grow, shrink, and deallocate arbitrary blocks of
│ │ │ │ data described via Layout
.
│ │ │ │ Allocator
is designed to be implemented on ZSTs, references, or smart pointers because having
│ │ │ │ an allocator like MyAlloc([u8; N])
cannot be moved, without updating the pointers to the
│ │ │ │ allocated memory.
│ │ │ │ Unlike GlobalAlloc
, zero-sized allocations are allowed in Allocator
. If an underlying
│ │ │ │ allocator does not support this (like jemalloc) or return a null pointer (such as
│ │ │ │ @@ -83,16 +83,16 @@
│ │ │ │ allocator. A copied or cloned allocator must behave like the same allocator, and
│ │ │ │
│ │ │ │
│ │ │ │ any pointer to a memory block which is currently allocated may be passed to any other
│ │ │ │ method of the allocator.
│ │ │ │
│ │ │ │
│ │ │ │ -Required Methods§
sourcefn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to allocate a block of memory.
│ │ │ │ -On success, returns a NonNull<[u8]>
meeting the size and alignment guarantees of layout
.
│ │ │ │ +Required Methods§
sourcefn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to allocate a block of memory.
│ │ │ │ +On success, returns a NonNull<[u8]>
meeting the size and alignment guarantees of layout
.
│ │ │ │ The returned block may have a larger size than specified by layout.size()
, and may or may
│ │ │ │ not have its contents initialized.
│ │ │ │ The returned block of memory remains valid as long as it is [currently allocated] and the shorter of:
│ │ │ │
│ │ │ │ - the borrow-checker lifetime of the allocator type itself.
│ │ │ │ - as long as at the allocator and all its clones has not been dropped.
│ │ │ │
│ │ │ │ @@ -100,36 +100,36 @@
│ │ │ │ Returning Err
indicates that either memory is exhausted or layout
does not meet
│ │ │ │ allocator’s size or alignment constraints.
│ │ │ │ Implementations are encouraged to return Err
on memory exhaustion rather than panicking or
│ │ │ │ aborting, but this is not a strict requirement. (Specifically: it is legal to implement
│ │ │ │ this trait atop an underlying native allocation library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an allocation error are encouraged to
│ │ │ │ call the handle_alloc_error
function, rather than directly invoking panic!
or similar.
│ │ │ │ -sourceunsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Deallocates the memory referenced by ptr
.
│ │ │ │ +sourceunsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Deallocates the memory referenced by ptr
.
│ │ │ │ §Safety
│ │ │ │
│ │ │ │ ptr
must denote a block of memory currently allocated via this allocator, and
│ │ │ │ layout
must fit that block of memory.
│ │ │ │
│ │ │ │ -Provided Methods§
sourcefn allocate_zeroed(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Behaves like allocate
, but also ensures that the returned memory is zero-initialized.
│ │ │ │ +Provided Methods§
sourcefn allocate_zeroed(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Behaves like allocate
, but also ensures that the returned memory is zero-initialized.
│ │ │ │ §Errors
│ │ │ │ Returning Err
indicates that either memory is exhausted or layout
does not meet
│ │ │ │ allocator’s size or alignment constraints.
│ │ │ │ Implementations are encouraged to return Err
on memory exhaustion rather than panicking or
│ │ │ │ aborting, but this is not a strict requirement. (Specifically: it is legal to implement
│ │ │ │ this trait atop an underlying native allocation library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an allocation error are encouraged to
│ │ │ │ call the handle_alloc_error
function, rather than directly invoking panic!
or similar.
│ │ │ │ -sourceunsafe fn grow(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ -) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to extend the memory block.
│ │ │ │ -Returns a new NonNull<[u8]>
containing a pointer and the actual size of the allocated
│ │ │ │ +) -> Result<NonNull<[u8]>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to extend the memory block.
│ │ │ │ +Returns a new NonNull<[u8]>
containing a pointer and the actual size of the allocated
│ │ │ │ memory. The pointer is suitable for holding data described by new_layout
. To accomplish
│ │ │ │ this, the allocator may extend the allocation referenced by ptr
to fit the new layout.
│ │ │ │ If this returns Ok
, then ownership of the memory block referenced by ptr
has been
│ │ │ │ transferred to this allocator. Any access to the old ptr
is Undefined Behavior, even if the
│ │ │ │ allocation was grown in-place. The newly returned pointer is the only valid pointer
│ │ │ │ for accessing this memory now.
│ │ │ │ If this method returns Err
, then ownership of the memory block has not been transferred to
│ │ │ │ @@ -145,20 +145,20 @@
│ │ │ │
Returns Err
if the new layout does not meet the allocator’s size and alignment
│ │ │ │ constraints of the allocator, or if growing otherwise fails.
│ │ │ │ Implementations are encouraged to return Err
on memory exhaustion rather than panicking or
│ │ │ │ aborting, but this is not a strict requirement. (Specifically: it is legal to implement
│ │ │ │ this trait atop an underlying native allocation library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an allocation error are encouraged to
│ │ │ │ call the handle_alloc_error
function, rather than directly invoking panic!
or similar.
│ │ │ │ -sourceunsafe fn grow_zeroed(
│ │ │ │ +
sourceunsafe fn grow_zeroed(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ -) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Behaves like grow
, but also ensures that the new contents are set to zero before being
│ │ │ │ +) -> Result<NonNull<[u8]>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Behaves like grow
, but also ensures that the new contents are set to zero before being
│ │ │ │ returned.
│ │ │ │ The memory block will contain the following contents after a successful call to
│ │ │ │ grow_zeroed
:
│ │ │ │
│ │ │ │ - Bytes
0..old_layout.size()
are preserved from the original allocation.
│ │ │ │ - Bytes
old_layout.size()..old_size
will either be preserved or zeroed, depending on
│ │ │ │ the allocator implementation. old_size
refers to the size of the memory block prior
│ │ │ │ @@ -178,21 +178,21 @@
│ │ │ │ Returns Err
if the new layout does not meet the allocator’s size and alignment
│ │ │ │ constraints of the allocator, or if growing otherwise fails.
│ │ │ │ Implementations are encouraged to return Err
on memory exhaustion rather than panicking or
│ │ │ │ aborting, but this is not a strict requirement. (Specifically: it is legal to implement
│ │ │ │ this trait atop an underlying native allocation library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an allocation error are encouraged to
│ │ │ │ call the handle_alloc_error
function, rather than directly invoking panic!
or similar.
│ │ │ │ -
sourceunsafe fn shrink(
│ │ │ │ &self,
│ │ │ │ - ptr: NonNull<u8>,
│ │ │ │ + ptr: NonNull<u8>,
│ │ │ │ old_layout: Layout,
│ │ │ │ new_layout: Layout,
│ │ │ │ -) -> Result<NonNull<[u8]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to shrink the memory block.
│ │ │ │ -Returns a new NonNull<[u8]>
containing a pointer and the actual size of the allocated
│ │ │ │ +) -> Result<NonNull<[u8]>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Attempts to shrink the memory block.
│ │ │ │ +Returns a new NonNull<[u8]>
containing a pointer and the actual size of the allocated
│ │ │ │ memory. The pointer is suitable for holding data described by new_layout
. To accomplish
│ │ │ │ this, the allocator may shrink the allocation referenced by ptr
to fit the new layout.
│ │ │ │ If this returns Ok
, then ownership of the memory block referenced by ptr
has been
│ │ │ │ transferred to this allocator. Any access to the old ptr
is Undefined Behavior, even if the
│ │ │ │ allocation was shrunk in-place. The newly returned pointer is the only valid pointer
│ │ │ │ for accessing this memory now.
│ │ │ │ If this method returns Err
, then ownership of the memory block has not been transferred to
│ │ │ │ @@ -208,12 +208,12 @@
│ │ │ │
Returns Err
if the new layout does not meet the allocator’s size and alignment
│ │ │ │ constraints of the allocator, or if shrinking otherwise fails.
│ │ │ │ Implementations are encouraged to return Err
on memory exhaustion rather than panicking or
│ │ │ │ aborting, but this is not a strict requirement. (Specifically: it is legal to implement
│ │ │ │ this trait atop an underlying native allocation library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an allocation error are encouraged to
│ │ │ │ call the handle_alloc_error
function, rather than directly invoking panic!
or similar.
│ │ │ │ -Implementors§
│ │ │ │ +
pub unsafe trait GlobalAlloc {
│ │ │ │ +GlobalAlloc in alloc::alloc - Rust pub unsafe trait GlobalAlloc {
│ │ │ │ // Required methods
│ │ │ │ - unsafe fn alloc(&self, layout: Layout) -> *mut u8;
│ │ │ │ - unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout);
│ │ │ │ + unsafe fn alloc(&self, layout: Layout) -> *mut u8;
│ │ │ │ + unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout);
│ │ │ │
│ │ │ │ // Provided methods
│ │ │ │ - unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8 { ... }
│ │ │ │ + unsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8 { ... }
│ │ │ │ unsafe fn realloc(
│ │ │ │ &self,
│ │ │ │ - ptr: *mut u8,
│ │ │ │ + ptr: *mut u8,
│ │ │ │ layout: Layout,
│ │ │ │ - new_size: usize,
│ │ │ │ - ) -> *mut u8 { ... }
│ │ │ │ + new_size: usize,
│ │ │ │ + ) -> *mut u8 { ... }
│ │ │ │ }
Expand description
A memory allocator that can be registered as the standard library’s default
│ │ │ │ through the #[global_allocator]
attribute.
│ │ │ │ Some of the methods require that a memory block be currently
│ │ │ │ allocated via an allocator. This means that:
│ │ │ │
│ │ │ │ -
│ │ │ │
the starting address for that memory block was previously
│ │ │ │ @@ -119,15 +119,15 @@
│ │ │ │ optimization that can be applied. You may generally not rely on heap allocations
│ │ │ │ happening if they can be removed without changing program behavior.
│ │ │ │ Whether allocations happen or not is not part of the program behavior, even if it
│ │ │ │ could be detected via an allocator that tracks allocations by printing or otherwise
│ │ │ │ having side effects.
│ │ │ │
│ │ │ │
│ │ │ │ -Required Methods§
1.28.0 · sourceunsafe fn alloc(&self, layout: Layout) -> *mut u8
Allocates memory as described by the given layout
.
│ │ │ │ +Required Methods§
1.28.0 · sourceunsafe fn alloc(&self, layout: Layout) -> *mut u8
Allocates memory as described by the given layout
.
│ │ │ │ Returns a pointer to newly-allocated memory,
│ │ │ │ or null to indicate allocation failure.
│ │ │ │ §Safety
│ │ │ │ layout
must have non-zero size. Attempting to allocate for a zero-sized layout
may
│ │ │ │ result in undefined behavior.
│ │ │ │ (Extension subtraits might provide more specific bounds on
│ │ │ │ behavior, e.g., guarantee a sentinel address or a null pointer
│ │ │ │ @@ -140,46 +140,46 @@
│ │ │ │ exhaustion rather than aborting, but this is not
│ │ │ │ a strict requirement. (Specifically: it is legal to
│ │ │ │ implement this trait atop an underlying native allocation
│ │ │ │ library that aborts on memory exhaustion.)
│ │ │ │ Clients wishing to abort computation in response to an
│ │ │ │ allocation error are encouraged to call the handle_alloc_error
function,
│ │ │ │ rather than directly invoking panic!
or similar.
│ │ │ │ -1.28.0 · sourceunsafe fn dealloc(&self, ptr: *mut u8, layout: Layout)
Deallocates the block of memory at the given ptr
pointer with the given layout
.
│ │ │ │ +1.28.0 · sourceunsafe fn dealloc(&self, ptr: *mut u8, layout: Layout)
Deallocates the block of memory at the given ptr
pointer with the given layout
.
│ │ │ │ §Safety
│ │ │ │ The caller must ensure:
│ │ │ │
│ │ │ │ -
│ │ │ │
ptr
is a block of memory currently allocated via this allocator and,
│ │ │ │
│ │ │ │ -
│ │ │ │
layout
is the same layout that was used to allocate that block of
│ │ │ │ memory.
│ │ │ │
│ │ │ │
│ │ │ │ Otherwise undefined behavior can result.
│ │ │ │ -Provided Methods§
1.28.0 · sourceunsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8
Behaves like alloc
, but also ensures that the contents
│ │ │ │ +
Provided Methods§
1.28.0 · sourceunsafe fn alloc_zeroed(&self, layout: Layout) -> *mut u8
Behaves like alloc
, but also ensures that the contents
│ │ │ │ are set to zero before being returned.
│ │ │ │ §Safety
│ │ │ │ The caller has to ensure that layout
has non-zero size. Like alloc
│ │ │ │ zero sized layout
can result in undefined behaviour.
│ │ │ │ However the allocated block of memory is guaranteed to be initialized.
│ │ │ │ §Errors
│ │ │ │ Returning a null pointer indicates that either memory is exhausted
│ │ │ │ or layout
does not meet allocator’s size or alignment constraints,
│ │ │ │ just as in alloc
.
│ │ │ │ Clients wishing to abort computation in response to an
│ │ │ │ allocation error are encouraged to call the handle_alloc_error
function,
│ │ │ │ rather than directly invoking panic!
or similar.
│ │ │ │ -1.28.0 · sourceunsafe fn realloc(
│ │ │ │ &self,
│ │ │ │ - ptr: *mut u8,
│ │ │ │ + ptr: *mut u8,
│ │ │ │ layout: Layout,
│ │ │ │ - new_size: usize,
│ │ │ │ -) -> *mut u8
Shrinks or grows a block of memory to the given new_size
in bytes.
│ │ │ │ + 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
.
│ │ │ │ If this returns a non-null pointer, then ownership of the memory block
│ │ │ │ referenced by ptr
has been transferred to this allocator.
│ │ │ │ Any access to the old ptr
is Undefined Behavior, even if the
│ │ │ │ allocation remained in-place. The newly returned pointer is the only valid pointer
│ │ │ │ for accessing this memory now.
│ │ │ │ The new memory block is allocated with layout
,
│ │ │ ├── ./usr/share/doc/rust-doc/html/alloc/alloc/type.LayoutErr.html
│ │ │ │ @@ -1 +1 @@
│ │ │ │ -
LayoutErr in alloc::alloc - Rust pub type LayoutErr = LayoutError;
👎Deprecated since 1.52.0: Name does not follow std convention, use LayoutErrorAliased Type§
struct LayoutErr;
│ │ │ │ +LayoutErr in alloc::alloc - Rust pub type LayoutErr = LayoutError;
👎Deprecated since 1.52.0: Name does not follow std convention, use LayoutErrorAliased Type§
struct LayoutErr;
│ │ │ ├── ./usr/share/doc/rust-doc/html/alloc/borrow/enum.Cow.html
│ │ │ │ @@ -1,10 +1,10 @@
│ │ │ │ Cow in alloc::borrow - Rust {
│ │ │ │ + Borrowed(&'a B),
│ │ │ │ Owned(<B as ToOwned>::Owned),
│ │ │ │ }Expand description
A clone-on-write smart pointer.
│ │ │ │ The type Cow
is a smart pointer providing clone-on-write functionality: it
│ │ │ │ can enclose and provide immutable access to borrowed data, and clone the
│ │ │ │ data lazily when mutation or ownership is required. The type is designed to
│ │ │ │ work with general borrowed data via the Borrow
trait.
│ │ │ │ Cow
implements Deref
, which means that you can call
│ │ │ │ @@ -69,27 +69,27 @@
│ │ │ │ println!("clone_on_write = {:?}", clone_on_write.values);
│ │ │ │
│ │ │ │ // The data was mutated. Let's check it out.
│ │ │ │ match clone_on_write {
│ │ │ │ Items { values: Cow::Owned(_) } => println!("clone_on_write contains owned data"),
│ │ │ │ _ => panic!("expect owned data"),
│ │ │ │ }
│ │ │ │ - Variants§
§1.36.0Borrowed(&'a B)
Borrowed data.
│ │ │ │ +Variants§
§1.36.0Borrowed(&'a B)
Borrowed data.
│ │ │ │ §1.36.0Owned(<B as ToOwned>::Owned)
Owned data.
│ │ │ │ -Implementations§
source§impl<B: ?Sized + ToOwned> Cow<'_, B>
sourcepub const fn is_borrowed(&self) -> bool
🔬This is a nightly-only experimental API. (cow_is_borrowed
#65143)
Returns true if the data is borrowed, i.e. if to_mut
would require additional work.
│ │ │ │ +Implementations§
source§impl<B: ?Sized + ToOwned> Cow<'_, B>
sourcepub const fn is_borrowed(&self) -> bool
🔬This is a nightly-only experimental API. (cow_is_borrowed
#65143)
Returns true if the data is borrowed, i.e. if to_mut
would require additional work.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub const fn is_owned(&self) -> bool
🔬This is a nightly-only experimental API. (cow_is_borrowed
#65143)
Returns true if the data is owned, i.e. if to_mut
would be a no-op.
│ │ │ │ +sourcepub const fn is_owned(&self) -> bool
🔬This is a nightly-only experimental API. (cow_is_borrowed
#65143)
Returns true if the data is owned, i.e. if to_mut
would be a no-op.
│ │ │ │ §Examples
│ │ │ │ #![feature(cow_is_borrowed)]
│ │ │ │ use std::borrow::Cow;
│ │ │ │
│ │ │ │ let cow: Cow<'_, str> = Cow::Owned("moo".to_string());
│ │ │ │ assert!(cow.is_owned());
│ │ │ │
│ │ │ │ @@ -129,179 +129,179 @@
│ │ │ │ let s = "Hello world!";
│ │ │ │ let cow: Cow<'_, str> = Cow::Owned(String::from(s));
│ │ │ │
│ │ │ │ assert_eq!(
│ │ │ │ cow.into_owned(),
│ │ │ │ String::from(s)
│ │ │ │ );
│ │ │ │ -Trait Implementations§
1.14.0 · source§impl<'a> AddAssign<&'a str> for Cow<'a, str>
source§fn add_assign(&mut self, rhs: &'a str)
Performs the +=
operation. Read more1.19.0 · source§impl<'a> Extend<Cow<'a, str>> for String
Trait Implementations§
1.14.0 · source§impl<'a> AddAssign<&'a str> for Cow<'a, str>
source§fn add_assign(&mut self, rhs: &'a str)
Performs the +=
operation. Read more1.19.0 · source§impl<'a> Extend<Cow<'a, str>> for String
1.28.0 · source§impl<'a> From<&'a String> for Cow<'a, str>
1.45.0 · source§impl From<Cow<'_, str>> for Box<str>
source§fn from(cow: Cow<'_, str>) -> Box<str>
Converts a Cow<'_, str>
into a Box<str>
│ │ │ │ When cow
is the Cow::Borrowed
variant, this
│ │ │ │ conversion allocates on the heap and copies the
│ │ │ │ underlying str
. Otherwise, it will try to reuse the owned
│ │ │ │ String
’s allocation.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │
│ │ │ │
│ │ │ │ -1.14.0 · source§impl<'a, T> From<Cow<'a, [T]>> for Vec<T>
source§fn from(s: Cow<'a, [T]>) -> Vec<T>
Converts a clone-on-write slice into a vector.
│ │ │ │ If s
already owns a Vec<T>
, it will be returned directly.
│ │ │ │ If s
is borrowing a slice, a new Vec<T>
will be allocated and
│ │ │ │ filled by cloning s
’s items into it.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.45.0 · source§impl<'a, B> From<Cow<'a, B>> for Arc<B>
1.45.0 · source§impl<'a, B> From<Cow<'a, B>> for Rc<B>
1.14.0 · source§impl<'a> From<Cow<'a, str>> for String
1.22.0 · source§impl<'a, 'b> From<Cow<'b, str>> for Box<dyn Error + 'a>
1.22.0 · source§impl<'a, 'b> From<Cow<'b, str>> for Box<dyn Error + Send + Sync + 'a>
source§fn from(err: Cow<'b, str>) -> Box<dyn Error + Send + Sync + 'a>
Converts a Cow
into a box of dyn Error
+ Send
+ Sync
.
│ │ │ │ §Examples
│ │ │ │ use std::error::Error;
│ │ │ │ use std::mem;
│ │ │ │ use std::borrow::Cow;
│ │ │ │
│ │ │ │ let a_cow_str_error = Cow::from("a str error");
│ │ │ │ let a_boxed_error = Box::<dyn Error + Send + Sync>::from(a_cow_str_error);
│ │ │ │ assert!(
│ │ │ │ mem::size_of::<Box<dyn Error + Send + Sync>>() == mem::size_of_val(&a_boxed_error))
│ │ │ │ -1.0.0 · source§impl<B> Ord for Cow<'_, B>
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
│ │ │ │ - Self: Sized,
Compares and returns the maximum of two values. Read more1.0.0 · source§impl<'a, B> PartialOrd for Cow<'a, B>
source§impl<B: ?Sized + ToOwned> DerefPure for Cow<'_, B>
1.0.0 · source§impl<B> Eq for Cow<'_, B>
Auto Trait Implementations§
§impl<'a, B> Freeze for Cow<'a, B>
§impl<'a, B> RefUnwindSafe for Cow<'a, B>
§impl<'a, B> Send for Cow<'a, B>
§impl<'a, B> Sync for Cow<'a, B>
§impl<'a, B> Unpin for Cow<'a, B>
§impl<'a, B> UnwindSafe for Cow<'a, B>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
│ │ │ │ - T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read moresource§impl<T> CloneToUninit for Twhere
│ │ │ │ - T: Clone,
1.0.0 · source§impl<B> Ord for Cow<'_, B>
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
│ │ │ │ + Self: Sized,
Compares and returns the maximum of two values. Read more1.0.0 · source§impl<'a, B> PartialOrd for Cow<'a, B>
source§impl<B: ?Sized + ToOwned> DerefPure for Cow<'_, B>
1.0.0 · source§impl<B> Eq for Cow<'_, B>
Auto Trait Implementations§
§impl<'a, B> Freeze for Cow<'a, B>
§impl<'a, B> RefUnwindSafe for Cow<'a, B>
§impl<'a, B> Send for Cow<'a, B>
§impl<'a, B> Sync for Cow<'a, B>
§impl<'a, B> Unpin for Cow<'a, B>
§impl<'a, B> UnwindSafe for Cow<'a, B>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
│ │ │ │ + T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read moresource§impl<T> CloneToUninit for Twhere
│ │ │ │ + T: Clone,
│ │ │ │ + T: Clone,source§fn clone_into(&self, target: &mut T)
Uses borrowed data to replace owned data, usually by cloning. Read more
│ │ │ ├── ./usr/share/doc/rust-doc/html/alloc/borrow/trait.Borrow.html
│ │ │ │ @@ -1,20 +1,20 @@
│ │ │ │ -Borrow in alloc::borrow - Rust pub trait Borrow<Borrowed>where
│ │ │ │ - Borrowed: ?Sized,{
│ │ │ │ +Borrow in alloc::borrow - Rust pub trait Borrow<Borrowed>where
│ │ │ │ + Borrowed: ?Sized,{
│ │ │ │ // Required method
│ │ │ │ - fn borrow(&self) -> &Borrowed;
│ │ │ │ + fn borrow(&self) -> &Borrowed;
│ │ │ │ }
Expand description
A trait for borrowing data.
│ │ │ │ In Rust, it is common to provide different representations of a type for
│ │ │ │ different use cases. For instance, storage location and management for a
│ │ │ │ value can be specifically chosen as appropriate for a particular use via
│ │ │ │ pointer types such as Box<T>
or Rc<T>
. Beyond these generic
│ │ │ │ wrappers that can be used with any type, some types provide optional
│ │ │ │ facets providing potentially costly functionality. An example for such a
│ │ │ │ type is String
which adds the ability to extend a string to the basic
│ │ │ │ -str
. This requires keeping additional information unnecessary for a
│ │ │ │ +str
. This requires keeping additional information unnecessary for a
│ │ │ │ simple, immutable string.
│ │ │ │ These types provide access to the underlying data through references
│ │ │ │ to the type of that data. They are said to be ‘borrowed as’ that type.
│ │ │ │ For instance, a Box<T>
can be borrowed as T
while a String
│ │ │ │ can be borrowed as str
.
│ │ │ │ Types express that they can be borrowed as some type T
by implementing
│ │ │ │ Borrow<T>
, providing a reference to a T
in the trait’s
│ │ │ │ @@ -28,22 +28,22 @@
│ │ │ │ on the identical behavior of these additional trait implementations.
│ │ │ │ These traits will likely appear as additional trait bounds.
│ │ │ │ In particular Eq
, Ord
and Hash
must be equivalent for
│ │ │ │ borrowed and owned values: x.borrow() == y.borrow()
should give the
│ │ │ │ same result as x == y
.
│ │ │ │ If generic code merely needs to work for all types that can
│ │ │ │ provide a reference to related type T
, it is often better to use
│ │ │ │ -AsRef<T>
as more types can safely implement it.
│ │ │ │ +AsRef<T>
as more types can safely implement it.
│ │ │ │ §Examples
│ │ │ │ As a data collection, HashMap<K, V>
owns both keys and values. If
│ │ │ │ the key’s actual data is wrapped in a managing type of some kind, it
│ │ │ │ should, however, still be possible to search for a value using a
│ │ │ │ reference to the key’s data. For instance, if the key is a string, then
│ │ │ │ it is likely stored with the hash map as a String
, while it should
│ │ │ │ -be possible to search using a &str
. Thus, insert
needs to
│ │ │ │ +be possible to search using a &str
. Thus, insert
needs to
│ │ │ │ operate on a String
while get
needs to be able to use a &str
.
│ │ │ │ Slightly simplified, the relevant parts of HashMap<K, V>
look like
│ │ │ │ this:
│ │ │ │
│ │ │ │ use std::borrow::Borrow;
│ │ │ │ use std::hash::Hash;
│ │ │ │
│ │ │ │ @@ -111,27 +111,27 @@
│ │ │ │ }
│ │ │ │ Can CaseInsensitiveString
implement Borrow<str>
? It certainly can
│ │ │ │ provide a reference to a string slice via its contained owned string.
│ │ │ │ But because its Hash
implementation differs, it behaves differently
│ │ │ │ from str
and therefore must not, in fact, implement Borrow<str>
.
│ │ │ │ If it wants to allow others access to the underlying str
, it can do
│ │ │ │ that via AsRef<str>
which doesn’t carry any extra requirements.
│ │ │ │ -Required Methods§
Required Methods§
Implementors§
1.0.0 · source§impl Borrow<str> for String
1.3.0 · source§impl Borrow<CStr> for CString
1.0.0 · source§impl<'a, B> Borrow<B> for Cow<'a, B>
1.0.0 · source§impl<T> Borrow<T> for &Twhere
│ │ │ │ - T: ?Sized,
1.0.0 · source§impl<T> Borrow<T> for &mut Twhere
│ │ │ │ - T: ?Sized,
1.0.0 · source§impl<T> Borrow<T> for Twhere
│ │ │ │ - T: ?Sized,
1.0.0 · source§impl<T, A: Allocator> Borrow<[T]> for Vec<T, A>
1.4.0 · source§impl<T, const N: usize> Borrow<[T]> for [T; N]
1.1.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Box<T, A>
1.0.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Rc<T, A>
1.0.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Arc<T, A>
│ │ │ │ +
Implementors§
1.0.0 · source§impl Borrow<str> for String
1.3.0 · source§impl Borrow<CStr> for CString
1.0.0 · source§impl<'a, B> Borrow<B> for Cow<'a, B>
1.0.0 · source§impl<T> Borrow<T> for &Twhere
│ │ │ │ + T: ?Sized,
1.0.0 · source§impl<T> Borrow<T> for &mut Twhere
│ │ │ │ + T: ?Sized,
1.0.0 · source§impl<T> Borrow<T> for Twhere
│ │ │ │ + T: ?Sized,
1.0.0 · source§impl<T, A: Allocator> Borrow<[T]> for Vec<T, A>
1.4.0 · source§impl<T, const N: usize> Borrow<[T]> for [T; N]
1.1.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Box<T, A>
1.0.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Rc<T, A>
1.0.0 · source§impl<T: ?Sized, A: Allocator> Borrow<T> for Arc<T, A>
│ │ │ ├── ./usr/share/doc/rust-doc/html/alloc/borrow/trait.BorrowMut.html
│ │ │ │ @@ -1,22 +1,22 @@
│ │ │ │ -BorrowMut in alloc::borrow - Rust pub trait BorrowMut<Borrowed>: Borrow<Borrowed>where
│ │ │ │ - Borrowed: ?Sized,{
│ │ │ │ +BorrowMut in alloc::borrow - Rust pub trait BorrowMut<Borrowed>: Borrow<Borrowed>where
│ │ │ │ + Borrowed: ?Sized,{
│ │ │ │ // Required method
│ │ │ │ - fn borrow_mut(&mut self) -> &mut Borrowed;
│ │ │ │ + fn borrow_mut(&mut self) -> &mut Borrowed;
│ │ │ │ }
Expand description
Required Methods§
1.0.0 · sourcefn borrow_mut(&mut self) -> &mut Borrowed
Mutably borrows from an owned value.
│ │ │ │ +Required Methods§
1.0.0 · sourcefn borrow_mut(&mut self) -> &mut Borrowed
Mutably borrows from an owned value.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -Implementors§
1.36.0 · source§impl BorrowMut<str> for String
1.0.0 · source§impl<T> BorrowMut<T> for &mut Twhere
│ │ │ │ - T: ?Sized,
1.0.0 · source§impl<T> BorrowMut<T> for Twhere
│ │ │ │ - T: ?Sized,
1.0.0 · source§impl<T, A: Allocator> BorrowMut<[T]> for Vec<T, A>
1.4.0 · source§impl<T, const N: usize> BorrowMut<[T]> for [T; N]
1.1.0 · source§impl<T: ?Sized, A: Allocator> BorrowMut<T> for Box<T, A>
│ │ │ │ +
Implementors§
1.36.0 · source§impl BorrowMut<str> for String
1.0.0 · source§impl<T> BorrowMut<T> for &mut Twhere
│ │ │ │ + T: ?Sized,
1.0.0 · source§impl<T> BorrowMut<T> for Twhere
│ │ │ │ + T: ?Sized,
1.0.0 · source§impl<T, A: Allocator> BorrowMut<[T]> for Vec<T, A>
1.4.0 · source§impl<T, const N: usize> BorrowMut<[T]> for [T; N]
1.1.0 · source§impl<T: ?Sized, A: Allocator> BorrowMut<T> for Box<T, A>
Uses borrowed data to replace owned data, usually by cloning.
│ │ │ │ -This is borrow-generalized version of Clone::clone_from
.
This is borrow-generalized version of Clone::clone_from
.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -isize::MAX
bytes.
│ │ │ │ Move a value from the stack to the heap by creating a Box
:
Move a value from a Box
back to the stack by dereferencing:
Move a value from a Box
back to the stack by dereferencing:
Creating a recursive data structure:
│ │ │ │ │ │ │ │#[allow(dead_code)]
│ │ │ │ #[derive(Debug)]
│ │ │ │ @@ -39,15 +39,15 @@
│ │ │ │ pointer points to a valid value of the right type. More precisely, a value: *mut T
that has
│ │ │ │ been allocated with the Global
allocator with Layout::for_value(&*value)
may be converted
│ │ │ │ into a box using Box::<T>::from_raw(value)
. Conversely, the memory backing a value: *mut T
│ │ │ │ obtained from Box::<T>::into_raw
may be deallocated using the Global
allocator with
│ │ │ │ Layout::for_value(&*value)
.
│ │ │ │ For zero-sized values, the Box
pointer has to be non-null and sufficiently aligned. The
│ │ │ │ recommended way to build a Box to a ZST if Box::new
cannot be used is to use
│ │ │ │ -ptr::NonNull::dangling
.
│ │ │ │ +ptr::NonNull::dangling
.
│ │ │ │ On top of these basic layout requirements, a Box<T>
must point to a valid value of T
.
│ │ │ │ So long as T: Sized
, a Box<T>
is guaranteed to be represented
│ │ │ │ as a single pointer and is also ABI-compatible with C pointers
│ │ │ │ (i.e. the C type T*
). This means that if you have extern “C”
│ │ │ │ Rust functions that will be called from C, you can define those
│ │ │ │ Rust functions using Box<T>
types, and use T*
as corresponding
│ │ │ │ type on the C side. As an example, consider this C header which
│ │ │ │ @@ -96,15 +96,15 @@
│ │ │ │
The aliasing rules for Box<T>
are the same as for &mut T
. Box<T>
│ │ │ │ asserts uniqueness over its content. Using raw pointers derived from a box
│ │ │ │ after that box has been mutated through, moved or borrowed as &mut T
│ │ │ │ is not allowed. For more guidance on working with box from unsafe code, see
│ │ │ │ rust-lang/unsafe-code-guidelines#326.
│ │ │ │ §Editions
│ │ │ │ A special case exists for the implementation of IntoIterator
for arrays on the Rust 2021
│ │ │ │ -edition, as documented here. Unfortunately, it was later found that a similar
│ │ │ │ +edition, as documented here. Unfortunately, it was later found that a similar
│ │ │ │ workaround should be added for boxed slices, and this was applied in the 2024 edition.
│ │ │ │ Specifically, IntoIterator
is implemented for Box<[T]>
on all editions, but specific calls
│ │ │ │ to into_iter()
for boxed slices will defer to the slice implementation on editions before
│ │ │ │ 2024:
│ │ │ │
│ │ │ │ ⓘ// Rust 2015, 2018, and 2021:
│ │ │ ├── ./usr/share/doc/rust-doc/html/alloc/boxed/struct.Box.html
│ │ │ │ @@ -1,67 +1,67 @@
│ │ │ │ -Box in alloc::boxed - Rust pub struct Box<T: ?Sized, A: Allocator = Global>(/* private fields */);
Expand description
A pointer type that uniquely owns a heap allocation of type T
.
│ │ │ │ +Box in alloc::boxed - Rust pub struct Box<T: ?Sized, A: Allocator = Global>(/* private fields */);
Expand description
A pointer type that uniquely owns a heap allocation of type T
.
│ │ │ │ See the module-level documentation for more.
│ │ │ │ Implementations§
source§impl<T> Box<T>
1.0.0 · sourcepub fn new(x: T) -> Self
Allocates memory on the heap and then places x
into it.
│ │ │ │ This doesn’t actually allocate if T
is zero-sized.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.82.0 · sourcepub fn new_uninit() -> Box<MaybeUninit<T>>
Constructs a new box with uninitialized contents.
│ │ │ │ +1.82.0 · sourcepub fn new_uninit() -> Box<MaybeUninit<T>>
Constructs a new box with uninitialized contents.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn new_zeroed() -> Box<MaybeUninit<T>>
🔬This is a nightly-only experimental API. (new_zeroed_alloc
#129396)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ +
sourcepub fn new_zeroed() -> Box<MaybeUninit<T>>
🔬This is a nightly-only experimental API. (new_zeroed_alloc
#129396)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.33.0 · sourcepub fn pin(x: T) -> Pin<Box<T>>
Constructs a new Pin<Box<T>>
. If T
does not implement Unpin
, then
│ │ │ │ +
1.33.0 · sourcepub fn pin(x: T) -> Pin<Box<T>>
Constructs a new Pin<Box<T>>
. If T
does not implement Unpin
, then
│ │ │ │ x
will be pinned in memory and unable to be moved.
│ │ │ │ Constructing and pinning of the Box
can also be done in two steps: Box::pin(x)
│ │ │ │ does the same as Box::into_pin(Box::new(x))
. Consider using
│ │ │ │ into_pin
if you already have a Box<T>
, or if you want to
│ │ │ │ construct a (pinned) Box
in a different way than with Box::new
.
│ │ │ │ -sourcepub fn try_new(x: T) -> Result<Self, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Allocates memory on the heap then places x
into it,
│ │ │ │ +
sourcepub fn try_new(x: T) -> Result<Self, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Allocates memory on the heap then places x
into it,
│ │ │ │ returning an error if the allocation fails
│ │ │ │ This doesn’t actually allocate if T
is zero-sized.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn try_new_uninit() -> Result<Box<MaybeUninit<T>>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new box with uninitialized contents on the heap,
│ │ │ │ +
sourcepub fn try_new_uninit() -> Result<Box<MaybeUninit<T>>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new box with uninitialized contents on the heap,
│ │ │ │ returning an error if the allocation fails
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn try_new_zeroed() -> Result<Box<MaybeUninit<T>>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ +
sourcepub fn try_new_zeroed() -> Result<Box<MaybeUninit<T>>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes on the heap
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │ #![feature(allocator_api)]
│ │ │ │
│ │ │ │ let zero = Box::<u32>::try_new_zeroed()?;
│ │ │ │ let zero = unsafe { zero.assume_init() };
│ │ │ │
│ │ │ │ @@ -71,25 +71,25 @@
│ │ │ │ This doesn’t actually allocate if T
is zero-sized.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -
sourcepub fn try_new_in(x: T, alloc: A) -> Result<Self, AllocError>where
│ │ │ │ +
sourcepub fn try_new_in(x: T, alloc: A) -> Result<Self, AllocError>where
│ │ │ │ A: Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Allocates memory in the given allocator then places x
into it,
│ │ │ │ returning an error if the allocation fails
│ │ │ │ This doesn’t actually allocate if T
is zero-sized.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn new_uninit_in(alloc: A) -> Box<MaybeUninit<T>, A>where
│ │ │ │ +
sourcepub fn new_uninit_in(alloc: A) -> Box<MaybeUninit<T>, A>where
│ │ │ │ A: Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new box with uninitialized contents in the provided allocator.
│ │ │ │ §Examples
│ │ │ │ #![feature(allocator_api)]
│ │ │ │
│ │ │ │ use std::alloc::System;
│ │ │ │
│ │ │ │ let mut five = Box::<u32, _>::new_uninit_in(System);
│ │ │ │ @@ -98,15 +98,15 @@
│ │ │ │ // Deferred initialization:
│ │ │ │ five.as_mut_ptr().write(5);
│ │ │ │
│ │ │ │ five.assume_init()
│ │ │ │ };
│ │ │ │
│ │ │ │ assert_eq!(*five, 5)
│ │ │ │ -sourcepub fn try_new_uninit_in(alloc: A) -> Result<Box<MaybeUninit<T>, A>, AllocError>where
│ │ │ │ +
sourcepub fn try_new_uninit_in(alloc: A) -> Result<Box<MaybeUninit<T>, A>, AllocError>where
│ │ │ │ A: Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new box with uninitialized contents in the provided allocator,
│ │ │ │ returning an error if the allocation fails
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn new_zeroed_in(alloc: A) -> Box<MaybeUninit<T>, A>where
│ │ │ │ +
sourcepub fn new_zeroed_in(alloc: A) -> Box<MaybeUninit<T>, A>where
│ │ │ │ A: Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes in the provided allocator.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn try_new_zeroed_in(alloc: A) -> Result<Box<MaybeUninit<T>, A>, AllocError>where
│ │ │ │ +
sourcepub fn try_new_zeroed_in(alloc: A) -> Result<Box<MaybeUninit<T>, A>, AllocError>where
│ │ │ │ A: Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Box
with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes in the provided allocator,
│ │ │ │ returning an error if the allocation fails,
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -sourcepub fn pin_in(x: T, alloc: A) -> Pin<Self>where
│ │ │ │ - A: 'static + Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Pin<Box<T, A>>
. If T
does not implement Unpin
, then
│ │ │ │ +
sourcepub fn pin_in(x: T, alloc: A) -> Pin<Self>where
│ │ │ │ + A: 'static + Allocator,
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new Pin<Box<T, A>>
. If T
does not implement Unpin
, then
│ │ │ │ x
will be pinned in memory and unable to be moved.
│ │ │ │ Constructing and pinning of the Box
can also be done in two steps: Box::pin_in(x, alloc)
│ │ │ │ does the same as Box::into_pin(Box::new_in(x, alloc))
. Consider using
│ │ │ │ into_pin
if you already have a Box<T, A>
, or if you want to
│ │ │ │ construct a (pinned) Box
in a different way than with Box::new_in
.
│ │ │ │ -sourcepub fn into_boxed_slice(boxed: Self) -> Box<[T], A>
🔬This is a nightly-only experimental API. (box_into_boxed_slice
#71582)
Converts a Box<T>
into a Box<[T]>
│ │ │ │ +sourcepub fn into_boxed_slice(boxed: Self) -> Box<[T], A>
🔬This is a nightly-only experimental API. (box_into_boxed_slice
#71582)
Converts a Box<T>
into a Box<[T]>
│ │ │ │ This conversion does not allocate on the heap and happens in place.
│ │ │ │ sourcepub fn into_inner(boxed: Self) -> T
🔬This is a nightly-only experimental API. (box_into_inner
#80437)
Consumes the Box
, returning the wrapped value.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -source§impl<T> Box<[T]>
1.82.0 · sourcepub fn new_uninit_slice(len: usize) -> Box<[MaybeUninit<T>]>
Constructs a new boxed slice with uninitialized contents.
│ │ │ │ +source§impl<T> Box<[T]>
1.82.0 · sourcepub fn new_uninit_slice(len: usize) -> Box<[MaybeUninit<T>]>
Constructs a new boxed slice with uninitialized contents.
│ │ │ │ §Examples
│ │ │ │ let mut values = Box::<[u32]>::new_uninit_slice(3);
│ │ │ │
│ │ │ │ let values = unsafe {
│ │ │ │ // Deferred initialization:
│ │ │ │ values[0].as_mut_ptr().write(1);
│ │ │ │ values[1].as_mut_ptr().write(2);
│ │ │ │ values[2].as_mut_ptr().write(3);
│ │ │ │
│ │ │ │ values.assume_init()
│ │ │ │ };
│ │ │ │
│ │ │ │ assert_eq!(*values, [1, 2, 3])
│ │ │ │ -sourcepub fn new_zeroed_slice(len: usize) -> Box<[MaybeUninit<T>]>
🔬This is a nightly-only experimental API. (new_zeroed_alloc
#129396)
Constructs a new boxed slice with uninitialized contents, with the memory
│ │ │ │ +
sourcepub fn new_zeroed_slice(len: usize) -> Box<[MaybeUninit<T>]>
🔬This is a nightly-only experimental API. (new_zeroed_alloc
#129396)
Constructs a new boxed slice with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ sourcepub fn try_new_uninit_slice(
│ │ │ │ - len: usize,
│ │ │ │ -) -> Result<Box<[MaybeUninit<T>]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents. Returns an error if
│ │ │ │ + len: usize,
│ │ │ │ +) -> Result<Box<[MaybeUninit<T>]>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents. Returns an error if
│ │ │ │ the allocation fails.
│ │ │ │ §Examples
│ │ │ │ #![feature(allocator_api)]
│ │ │ │
│ │ │ │ let mut values = Box::<[u32]>::try_new_uninit_slice(3)?;
│ │ │ │ let values = unsafe {
│ │ │ │ // Deferred initialization:
│ │ │ │ @@ -204,27 +204,27 @@
│ │ │ │ values[1].as_mut_ptr().write(2);
│ │ │ │ values[2].as_mut_ptr().write(3);
│ │ │ │ values.assume_init()
│ │ │ │ };
│ │ │ │
│ │ │ │ assert_eq!(*values, [1, 2, 3]);
│ │ │ │ sourcepub fn try_new_zeroed_slice(
│ │ │ │ - len: usize,
│ │ │ │ -) -> Result<Box<[MaybeUninit<T>]>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents, with the memory
│ │ │ │ + len: usize,
│ │ │ │ +) -> Result<Box<[MaybeUninit<T>]>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents, with the memory
│ │ │ │ being filled with 0
bytes. Returns an error if the allocation fails.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -source§impl<T, A: Allocator> Box<[T], A>
sourcepub fn new_uninit_slice_in(len: usize, alloc: A) -> Box<[MaybeUninit<T>], A>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator.
│ │ │ │ +source§impl<T, A: Allocator> Box<[T], A>
sourcepub fn new_uninit_slice_in(len: usize, alloc: A) -> Box<[MaybeUninit<T>], A>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator.
│ │ │ │ §Examples
│ │ │ │ #![feature(allocator_api)]
│ │ │ │
│ │ │ │ use std::alloc::System;
│ │ │ │
│ │ │ │ let mut values = Box::<[u32], _>::new_uninit_slice_in(3, System);
│ │ │ │
│ │ │ │ @@ -234,31 +234,31 @@
│ │ │ │ values[1].as_mut_ptr().write(2);
│ │ │ │ values[2].as_mut_ptr().write(3);
│ │ │ │
│ │ │ │ values.assume_init()
│ │ │ │ };
│ │ │ │
│ │ │ │ assert_eq!(*values, [1, 2, 3])
│ │ │ │ -sourcepub fn new_zeroed_slice_in(len: usize, alloc: A) -> Box<[MaybeUninit<T>], A>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator,
│ │ │ │ +
sourcepub fn new_zeroed_slice_in(len: usize, alloc: A) -> Box<[MaybeUninit<T>], A>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator,
│ │ │ │ with the memory being filled with 0
bytes.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ sourcepub fn try_new_uninit_slice_in(
│ │ │ │ - len: usize,
│ │ │ │ + len: usize,
│ │ │ │ alloc: A,
│ │ │ │ -) -> Result<Box<[MaybeUninit<T>], A>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator. Returns an error if
│ │ │ │ +) -> Result<Box<[MaybeUninit<T>], A>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator. Returns an error if
│ │ │ │ the allocation fails.
│ │ │ │ §Examples
│ │ │ │ #![feature(allocator_api)]
│ │ │ │
│ │ │ │ use std::alloc::System;
│ │ │ │
│ │ │ │ let mut values = Box::<[u32], _>::try_new_uninit_slice_in(3, System)?;
│ │ │ │ @@ -268,32 +268,32 @@
│ │ │ │ values[1].as_mut_ptr().write(2);
│ │ │ │ values[2].as_mut_ptr().write(3);
│ │ │ │ values.assume_init()
│ │ │ │ };
│ │ │ │
│ │ │ │ assert_eq!(*values, [1, 2, 3]);
│ │ │ │ sourcepub fn try_new_zeroed_slice_in(
│ │ │ │ - len: usize,
│ │ │ │ + len: usize,
│ │ │ │ alloc: A,
│ │ │ │ -) -> Result<Box<[MaybeUninit<T>], A>, AllocError>
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator, with the memory
│ │ │ │ +) -> Result<Box<[MaybeUninit<T>], A>, AllocError>🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a new boxed slice with uninitialized contents in the provided allocator, with the memory
│ │ │ │ being filled with 0
bytes. Returns an error if the allocation fails.
│ │ │ │ -See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ +
See MaybeUninit::zeroed
for examples of correct and incorrect usage
│ │ │ │ of this method.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -source§impl<T, A: Allocator> Box<MaybeUninit<T>, A>
1.82.0 · sourcepub unsafe fn assume_init(self) -> Box<T, A>
Converts to Box<T, A>
.
│ │ │ │ +source§impl<T, A: Allocator> Box<MaybeUninit<T>, A>
1.82.0 · sourcepub unsafe fn assume_init(self) -> Box<T, A>
Converts to Box<T, A>
.
│ │ │ │ §Safety
│ │ │ │ -As with MaybeUninit::assume_init
,
│ │ │ │ +
As with MaybeUninit::assume_init
,
│ │ │ │ it is up to the caller to guarantee that the value
│ │ │ │ really is in an initialized state.
│ │ │ │ Calling this when the content is not yet fully initialized
│ │ │ │ causes immediate undefined behavior.
│ │ │ │ §Examples
│ │ │ │ let mut five = Box::<u32>::new_uninit();
│ │ │ │
│ │ │ │ @@ -323,17 +323,17 @@
│ │ │ │ // The optimizer may be able to elide this copy, so previous code writes
│ │ │ │ // to heap directly.
│ │ │ │ let big_box = Box::write(big_box, array);
│ │ │ │
│ │ │ │ for (i, x) in big_box.iter().enumerate() {
│ │ │ │ assert_eq!(*x, i);
│ │ │ │ }
│ │ │ │ -source§impl<T, A: Allocator> Box<[MaybeUninit<T>], A>
1.82.0 · sourcepub unsafe fn assume_init(self) -> Box<[T], A>
Converts to Box<[T], A>
.
│ │ │ │ +source§impl<T, A: Allocator> Box<[MaybeUninit<T>], A>
1.82.0 · sourcepub unsafe fn assume_init(self) -> Box<[T], A>
Converts to Box<[T], A>
.
│ │ │ │ §Safety
│ │ │ │ -As with MaybeUninit::assume_init
,
│ │ │ │ +
As with MaybeUninit::assume_init
,
│ │ │ │ it is up to the caller to guarantee that the values
│ │ │ │ really are in an initialized state.
│ │ │ │ Calling this when the content is not yet fully initialized
│ │ │ │ causes immediate undefined behavior.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -source§impl<T: ?Sized> Box<T>
1.4.0 · sourcepub unsafe fn from_raw(raw: *mut T) -> Self
Constructs a box from a raw pointer.
│ │ │ │ After calling this function, the raw pointer is owned by the
│ │ │ │ resulting Box
. Specifically, the Box
destructor will call
│ │ │ │ the destructor of T
and free the allocated memory. For this
│ │ │ │ to be safe, the memory must have been allocated in accordance
│ │ │ │ with the memory layout used by Box
.
│ │ │ │ §Safety
│ │ │ │ This function is unsafe because improper use may lead to
│ │ │ │ @@ -373,15 +373,15 @@
│ │ │ │ let ptr = alloc(Layout::new::<i32>()) as *mut i32;
│ │ │ │ // In general .write is required to avoid attempting to destruct
│ │ │ │ // the (uninitialized) previous contents of `ptr`, though for this
│ │ │ │ // simple example `*ptr = 5` would have worked as well.
│ │ │ │ ptr.write(5);
│ │ │ │ let x = Box::from_raw(ptr);
│ │ │ │ }
│ │ │ │ -sourcepub unsafe fn from_non_null(ptr: NonNull<T>) -> Self
🔬This is a nightly-only experimental API. (box_vec_non_null
#130364)
Constructs a box from a NonNull
pointer.
│ │ │ │ +sourcepub unsafe fn from_non_null(ptr: NonNull<T>) -> Self
🔬This is a nightly-only experimental API. (box_vec_non_null
#130364)
Constructs a box from a NonNull
pointer.
│ │ │ │ After calling this function, the NonNull
pointer is owned by
│ │ │ │ the resulting Box
. Specifically, the Box
destructor will call
│ │ │ │ the destructor of T
and free the allocated memory. For this
│ │ │ │ to be safe, the memory must have been allocated in accordance
│ │ │ │ with the memory layout used by Box
.
│ │ │ │ §Safety
│ │ │ │ This function is unsafe because improper use may lead to
│ │ │ │ @@ -408,15 +408,15 @@
│ │ │ │ let non_null = NonNull::new(alloc(Layout::new::<i32>()).cast::<i32>())
│ │ │ │ .expect("allocation failed");
│ │ │ │ // In general .write is required to avoid attempting to destruct
│ │ │ │ // the (uninitialized) previous contents of `non_null`.
│ │ │ │ non_null.write(5);
│ │ │ │ let x = Box::from_non_null(non_null);
│ │ │ │ }
│ │ │ │ -source§impl<T: ?Sized, A: Allocator> Box<T, A>
sourcepub const unsafe fn from_raw_in(raw: *mut T, alloc: A) -> Self
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a box from a raw pointer in the given allocator.
│ │ │ │ +source§impl<T: ?Sized, A: Allocator> Box<T, A>
sourcepub const unsafe fn from_raw_in(raw: *mut T, alloc: A) -> Self
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a box from a raw pointer in the given allocator.
│ │ │ │ After calling this function, the raw pointer is owned by the
│ │ │ │ resulting Box
. Specifically, the Box
destructor will call
│ │ │ │ the destructor of T
and free the allocated memory. For this
│ │ │ │ to be safe, the memory must have been allocated in accordance
│ │ │ │ with the memory layout used by Box
.
│ │ │ │ §Safety
│ │ │ │ This function is unsafe because improper use may lead to
│ │ │ │ @@ -443,15 +443,15 @@
│ │ │ │ let ptr = System.allocate(Layout::new::<i32>())?.as_mut_ptr() as *mut i32;
│ │ │ │ // In general .write is required to avoid attempting to destruct
│ │ │ │ // the (uninitialized) previous contents of `ptr`, though for this
│ │ │ │ // simple example `*ptr = 5` would have worked as well.
│ │ │ │ ptr.write(5);
│ │ │ │ let x = Box::from_raw_in(ptr, System);
│ │ │ │ }
│ │ │ │ -sourcepub const unsafe fn from_non_null_in(raw: NonNull<T>, alloc: A) -> Self
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a box from a NonNull
pointer in the given allocator.
│ │ │ │ +sourcepub const unsafe fn from_non_null_in(raw: NonNull<T>, alloc: A) -> Self
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Constructs a box from a NonNull
pointer in the given allocator.
│ │ │ │ After calling this function, the NonNull
pointer is owned by
│ │ │ │ the resulting Box
. Specifically, the Box
destructor will call
│ │ │ │ the destructor of T
and free the allocated memory. For this
│ │ │ │ to be safe, the memory must have been allocated in accordance
│ │ │ │ with the memory layout used by Box
.
│ │ │ │ §Safety
│ │ │ │ This function is unsafe because improper use may lead to
│ │ │ │ @@ -477,15 +477,15 @@
│ │ │ │ unsafe {
│ │ │ │ let non_null = System.allocate(Layout::new::<i32>())?.cast::<i32>();
│ │ │ │ // In general .write is required to avoid attempting to destruct
│ │ │ │ // the (uninitialized) previous contents of `non_null`.
│ │ │ │ non_null.write(5);
│ │ │ │ let x = Box::from_non_null_in(non_null, System);
│ │ │ │ }
│ │ │ │ -1.4.0 · sourcepub fn into_raw(b: Self) -> *mut T
Consumes the Box
, returning a wrapped raw pointer.
│ │ │ │ +1.4.0 · sourcepub fn into_raw(b: Self) -> *mut T
Consumes the Box
, returning a wrapped raw pointer.
│ │ │ │ The pointer will be properly aligned and non-null.
│ │ │ │ After calling this function, the caller is responsible for the
│ │ │ │ memory previously managed by the Box
. In particular, the
│ │ │ │ caller should properly destroy T
and release the memory, taking
│ │ │ │ into account the memory layout used by Box
. The easiest way to
│ │ │ │ do this is to convert the raw pointer back into a Box
with the
│ │ │ │ Box::from_raw
function, allowing the Box
destructor to perform
│ │ │ │ @@ -515,15 +515,15 @@
│ │ │ │
Note: This is equivalent to the following:
│ │ │ │
│ │ │ │
│ │ │ │ -sourcepub fn into_non_null(b: Self) -> NonNull<T>
🔬This is a nightly-only experimental API. (box_vec_non_null
#130364)
Consumes the Box
, returning a wrapped NonNull
pointer.
│ │ │ │ +sourcepub fn into_non_null(b: Self) -> NonNull<T>
🔬This is a nightly-only experimental API. (box_vec_non_null
#130364)
Consumes the Box
, returning a wrapped NonNull
pointer.
│ │ │ │ The pointer will be properly aligned.
│ │ │ │ After calling this function, the caller is responsible for the
│ │ │ │ memory previously managed by the Box
. In particular, the
│ │ │ │ caller should properly destroy T
and release the memory, taking
│ │ │ │ into account the memory layout used by Box
. The easiest way to
│ │ │ │ do this is to convert the NonNull
pointer back into a Box
with the
│ │ │ │ Box::from_non_null
function, allowing the Box
destructor to
│ │ │ │ @@ -558,15 +558,15 @@
│ │ │ │
│ │ │ │ -sourcepub fn into_raw_with_allocator(b: Self) -> (*mut T, A)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Consumes the Box
, returning a wrapped raw pointer and the allocator.
│ │ │ │ +sourcepub fn into_raw_with_allocator(b: Self) -> (*mut T, A)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Consumes the Box
, returning a wrapped raw pointer and the allocator.
│ │ │ │ The pointer will be properly aligned and non-null.
│ │ │ │ After calling this function, the caller is responsible for the
│ │ │ │ memory previously managed by the Box
. In particular, the
│ │ │ │ caller should properly destroy T
and release the memory, taking
│ │ │ │ into account the memory layout used by Box
. The easiest way to
│ │ │ │ do this is to convert the raw pointer back into a Box
with the
│ │ │ │ Box::from_raw_in
function, allowing the Box
destructor to perform
│ │ │ │ @@ -596,15 +596,15 @@
│ │ │ │ let x = Box::new_in(String::from("Hello"), System);
│ │ │ │ let (ptr, alloc) = Box::into_raw_with_allocator(x);
│ │ │ │ unsafe {
│ │ │ │ ptr::drop_in_place(ptr);
│ │ │ │ let non_null = NonNull::new_unchecked(ptr);
│ │ │ │ alloc.deallocate(non_null.cast(), Layout::new::<String>());
│ │ │ │ }
│ │ │ │ -sourcepub fn into_non_null_with_allocator(b: Self) -> (NonNull<T>, A)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Consumes the Box
, returning a wrapped NonNull
pointer and the allocator.
│ │ │ │ +sourcepub fn into_non_null_with_allocator(b: Self) -> (NonNull<T>, A)
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Consumes the Box
, returning a wrapped NonNull
pointer and the allocator.
│ │ │ │ The pointer will be properly aligned.
│ │ │ │ After calling this function, the caller is responsible for the
│ │ │ │ memory previously managed by the Box
. In particular, the
│ │ │ │ caller should properly destroy T
and release the memory, taking
│ │ │ │ into account the memory layout used by Box
. The easiest way to
│ │ │ │ do this is to convert the NonNull
pointer back into a Box
with the
│ │ │ │ Box::from_non_null_in
function, allowing the Box
destructor to
│ │ │ │ @@ -633,15 +633,15 @@
│ │ │ │
│ │ │ │ let x = Box::new_in(String::from("Hello"), System);
│ │ │ │ let (non_null, alloc) = Box::into_non_null_with_allocator(x);
│ │ │ │ unsafe {
│ │ │ │ non_null.drop_in_place();
│ │ │ │ alloc.deallocate(non_null.cast::<u8>(), Layout::new::<String>());
│ │ │ │ }
│ │ │ │ -sourcepub fn as_mut_ptr(b: &mut Self) -> *mut T
🔬This is a nightly-only experimental API. (box_as_ptr
#129090)
Returns a raw mutable pointer to the Box
’s contents.
│ │ │ │ +sourcepub fn as_mut_ptr(b: &mut Self) -> *mut T
🔬This is a nightly-only experimental API. (box_as_ptr
#129090)
Returns a raw mutable pointer to the Box
’s contents.
│ │ │ │ The caller must ensure that the Box
outlives the pointer this
│ │ │ │ function returns, or else it will end up dangling.
│ │ │ │ This method guarantees that for the purpose of the aliasing model, this method
│ │ │ │ does not materialize a reference to the underlying memory, and thus the returned pointer
│ │ │ │ will remain valid when mixed with other calls to as_ptr
and as_mut_ptr
.
│ │ │ │ Note that calling other methods that materialize references to the memory
│ │ │ │ may still invalidate this pointer.
│ │ │ │ @@ -656,15 +656,15 @@
│ │ │ │ let ptr1 = Box::as_mut_ptr(&mut b);
│ │ │ │ ptr1.write(1);
│ │ │ │ let ptr2 = Box::as_mut_ptr(&mut b);
│ │ │ │ ptr2.write(2);
│ │ │ │ // Notably, the write to `ptr2` did *not* invalidate `ptr1`:
│ │ │ │ ptr1.write(3);
│ │ │ │ }
│ │ │ │ -sourcepub fn as_ptr(b: &Self) -> *const T
🔬This is a nightly-only experimental API. (box_as_ptr
#129090)
Returns a raw pointer to the Box
’s contents.
│ │ │ │ +sourcepub fn as_ptr(b: &Self) -> *const T
🔬This is a nightly-only experimental API. (box_as_ptr
#129090)
Returns a raw pointer to the Box
’s contents.
│ │ │ │ The caller must ensure that the Box
outlives the pointer this
│ │ │ │ function returns, or else it will end up dangling.
│ │ │ │ The caller must also ensure that the memory the pointer (non-transitively) points to
│ │ │ │ is never written to (except inside an UnsafeCell
) using this pointer or any pointer
│ │ │ │ derived from it. If you need to mutate the contents of the Box
, use as_mut_ptr
.
│ │ │ │ This method guarantees that for the purpose of the aliasing model, this method
│ │ │ │ does not materialize a reference to the underlying memory, and thus the returned pointer
│ │ │ │ @@ -685,19 +685,19 @@
│ │ │ │ // No write to this memory has happened yet, so `ptr1` is still valid.
│ │ │ │ let _val = ptr1.read();
│ │ │ │ // However, once we do a write...
│ │ │ │ ptr2.write(1);
│ │ │ │ // ... `ptr1` is no longer valid.
│ │ │ │ // This would be UB: let _val = ptr1.read();
│ │ │ │ }
│ │ │ │ -sourcepub const fn allocator(b: &Self) -> &A
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Returns a reference to the underlying allocator.
│ │ │ │ +sourcepub const fn allocator(b: &Self) -> &A
🔬This is a nightly-only experimental API. (allocator_api
#32838)
Returns a reference to the underlying allocator.
│ │ │ │ Note: this is an associated function, which means that you have
│ │ │ │ to call it as Box::allocator(&b)
instead of b.allocator()
. This
│ │ │ │ is so that there is no conflict with a method on the inner type.
│ │ │ │ -1.26.0 · sourcepub fn leak<'a>(b: Self) -> &'a mut Twhere
│ │ │ │ A: 'a,
Consumes and leaks the Box
, returning a mutable reference,
│ │ │ │ &'a mut T
.
│ │ │ │ Note that the type T
must outlive the chosen lifetime 'a
. If the type
│ │ │ │ has only static references, or none at all, then this may be chosen to be
│ │ │ │ 'static
.
│ │ │ │ This function is mainly useful for data that lives for the remainder of
│ │ │ │ the program’s life. Dropping the returned reference will cause a memory
│ │ │ │ @@ -717,19 +717,19 @@
│ │ │ │ assert_eq!(*static_ref, 42);
│ │ │ │ Unsized data:
│ │ │ │
│ │ │ │
│ │ │ │ -1.63.0 (const: unstable) · sourcepub fn into_pin(boxed: Self) -> Pin<Self>where
│ │ │ │ - A: 'static,
Converts a Box<T>
into a Pin<Box<T>>
. If T
does not implement Unpin
, then
│ │ │ │ +
1.63.0 (const: unstable) · sourcepub fn into_pin(boxed: Self) -> Pin<Self>where
│ │ │ │ + A: 'static,
Converts a Box<T>
into a Pin<Box<T>>
. If T
does not implement Unpin
, then
│ │ │ │ *boxed
will be pinned in memory and unable to be moved.
│ │ │ │ This conversion does not allocate on the heap and happens in place.
│ │ │ │ -This is also available via From
.
│ │ │ │ +This is also available via From
.
│ │ │ │ Constructing and pinning a Box
with Box::into_pin(Box::new(x))
│ │ │ │ can also be written more concisely using Box::pin(x)
.
│ │ │ │ This into_pin
method is useful if you already have a Box<T>
, or you are
│ │ │ │ constructing a (pinned) Box
in a different way than with Box::new
.
│ │ │ │ §Notes
│ │ │ │ It’s not recommended that crates add an impl like From<Box<T>> for Pin<T>
,
│ │ │ │ as it’ll introduce an ambiguity when calling Pin::from
.
│ │ │ │ @@ -740,295 +740,295 @@
│ │ │ │ fn from(_: Box<()>) -> Pin<Foo> {
│ │ │ │ Pin::new(Foo)
│ │ │ │ }
│ │ │ │ }
│ │ │ │
│ │ │ │ let foo = Box::new(());
│ │ │ │ let bar = Pin::from(foo);
│ │ │ │ -
source§impl<A: Allocator> Box<dyn Any, A>
1.0.0 · sourcepub fn downcast<T: Any>(self) -> Result<Box<T, A>, Self>
Attempts to downcast the box to a concrete type.
│ │ │ │ §Examples
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ fn print_if_string(value: Box<dyn Any>) {
│ │ │ │ if let Ok(string) = value.downcast::<String>() {
│ │ │ │ println!("String ({}): {}", string.len(), string);
│ │ │ │ }
│ │ │ │ }
│ │ │ │
│ │ │ │ let my_string = "Hello World".to_string();
│ │ │ │ print_if_string(Box::new(my_string));
│ │ │ │ print_if_string(Box::new(0i8));
│ │ │ │ -sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ +sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ For a safe alternative see downcast
.
│ │ │ │ §Examples
│ │ │ │ #![feature(downcast_unchecked)]
│ │ │ │
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ let x: Box<dyn Any> = Box::new(1_usize);
│ │ │ │
│ │ │ │ unsafe {
│ │ │ │ assert_eq!(*x.downcast_unchecked::<usize>(), 1);
│ │ │ │ }
│ │ │ │ §Safety
│ │ │ │ The contained value must be of type T
. Calling this method
│ │ │ │ with the incorrect type is undefined behavior.
│ │ │ │ -source§impl<A: Allocator> Box<dyn Any + Send, A>
1.0.0 · sourcepub fn downcast<T: Any>(self) -> Result<Box<T, A>, Self>
Attempts to downcast the box to a concrete type.
│ │ │ │ §Examples
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ fn print_if_string(value: Box<dyn Any + Send>) {
│ │ │ │ if let Ok(string) = value.downcast::<String>() {
│ │ │ │ println!("String ({}): {}", string.len(), string);
│ │ │ │ }
│ │ │ │ }
│ │ │ │
│ │ │ │ let my_string = "Hello World".to_string();
│ │ │ │ print_if_string(Box::new(my_string));
│ │ │ │ print_if_string(Box::new(0i8));
│ │ │ │ -sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ +sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ For a safe alternative see downcast
.
│ │ │ │ §Examples
│ │ │ │ #![feature(downcast_unchecked)]
│ │ │ │
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ let x: Box<dyn Any + Send> = Box::new(1_usize);
│ │ │ │
│ │ │ │ unsafe {
│ │ │ │ assert_eq!(*x.downcast_unchecked::<usize>(), 1);
│ │ │ │ }
│ │ │ │ §Safety
│ │ │ │ The contained value must be of type T
. Calling this method
│ │ │ │ with the incorrect type is undefined behavior.
│ │ │ │ -source§impl<A: Allocator> Box<dyn Any + Send + Sync, A>
1.51.0 · sourcepub fn downcast<T: Any>(self) -> Result<Box<T, A>, Self>
Attempts to downcast the box to a concrete type.
│ │ │ │ §Examples
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ fn print_if_string(value: Box<dyn Any + Send + Sync>) {
│ │ │ │ if let Ok(string) = value.downcast::<String>() {
│ │ │ │ println!("String ({}): {}", string.len(), string);
│ │ │ │ }
│ │ │ │ }
│ │ │ │
│ │ │ │ let my_string = "Hello World".to_string();
│ │ │ │ print_if_string(Box::new(my_string));
│ │ │ │ print_if_string(Box::new(0i8));
│ │ │ │ -sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ +sourcepub unsafe fn downcast_unchecked<T: Any>(self) -> Box<T, A>
🔬This is a nightly-only experimental API. (downcast_unchecked
#90850)
Downcasts the box to a concrete type.
│ │ │ │ For a safe alternative see downcast
.
│ │ │ │ §Examples
│ │ │ │ #![feature(downcast_unchecked)]
│ │ │ │
│ │ │ │ use std::any::Any;
│ │ │ │
│ │ │ │ let x: Box<dyn Any + Send + Sync> = Box::new(1_usize);
│ │ │ │
│ │ │ │ unsafe {
│ │ │ │ assert_eq!(*x.downcast_unchecked::<usize>(), 1);
│ │ │ │ }
│ │ │ │ §Safety
│ │ │ │ The contained value must be of type T
. Calling this method
│ │ │ │ with the incorrect type is undefined behavior.
│ │ │ │ -
async_fn_traits
)AsyncFn
, returning a future which may borrow from the called closure.async_fn_traits
)AsyncFn
, returning a future which may borrow from the called closure.async_fn_traits
)AsyncFnMut::async_call_mut
and AsyncFn::async_call
.async_fn_traits
)AsyncFnMut::async_call_mut
and AsyncFn::async_call
.async_fn_traits
)AsyncFnMut
, returning a future which may borrow from the called closure.async_fn_traits
)async_fn_traits
)AsyncFnOnce::async_call_once
.async_fn_traits
)AsyncFnMut
, returning a future which may borrow from the called closure.async_fn_traits
)async_fn_traits
)AsyncFnOnce::async_call_once
.async_fn_traits
)AsyncFnOnce
, returning a future which may move out of the called closure.async_iterator
#79024)async_iterator
#79024)async_fn_traits
)AsyncFnOnce
, returning a future which may move out of the called closure.async_iterator
#79024)async_iterator
#79024)None
if the async iterator is exhausted. Read moreCopies source
’s contents into self
without creating a new allocation,
│ │ │ │ +None
if the async iterator is exhausted. Read more
Copies source
’s contents into self
without creating a new allocation,
│ │ │ │ so long as the two are of the same length.
Returns a new box with a clone()
of this box’s contents.
Copies source
’s contents into self
without creating a new allocation.
Copies source
’s contents into self
without creating a new allocation.
coroutine_trait
#43122)coroutine_trait
#43122)coroutine_trait
#43122)coroutine_trait
#43122)n
th element from the end of the iterator. Read moreiter_advance_by
#77404)n
elements. Read moreIterator::try_fold()
: it takes
│ │ │ │ -elements starting from the back of the iterator. Read moreConverts a &[T]
into a Box<[T]>
coroutine_trait
#43122)n
th element from the end of the iterator. Read moreiter_advance_by
#77404)n
elements. Read moreIterator::try_fold()
: it takes
│ │ │ │ +elements starting from the back of the iterator. Read moreConverts a Box<T>
into a Pin<Box<T>>
. If T
does not implement Unpin
, then
│ │ │ │ *boxed
will be pinned in memory and unable to be moved.
This conversion does not allocate on the heap and happens in place.
│ │ │ │This is also available via Box::into_pin
.
Constructing and pinning a Box
with <Pin<Box<T>>>::from(Box::new(x))
│ │ │ │ can also be written more concisely using Box::pin(x)
.
│ │ │ │ This From
implementation is useful if you already have a Box<T>
, or you are
│ │ │ │ constructing a (pinned) Box
in a different way than with Box::new
.
Converts a Box<str>
into a Box<[u8]>
This conversion does not allocate on the heap and happens in place.
│ │ │ │// create a Box<str> which will be used to create a Box<[u8]>
│ │ │ │ let boxed: Box<str> = Box::from("hello");
│ │ │ │ let boxed_str: Box<[u8]> = Box::from(boxed);
│ │ │ │
│ │ │ │ // create a &[u8] which will be used to create a Box<[u8]>
│ │ │ │ let slice: &[u8] = &[104, 101, 108, 108, 111];
│ │ │ │ let boxed_slice = Box::from(slice);
│ │ │ │
│ │ │ │ assert_eq!(boxed_slice, boxed_str);
Converts a Cow<'_, str>
into a Box<str>
When cow
is the Cow::Borrowed
variant, this
│ │ │ │ conversion allocates on the heap and copies the
│ │ │ │ underlying str
. Otherwise, it will try to reuse the owned
│ │ │ │ String
’s allocation.
Converts a Cow
into a box of dyn Error
+ Send
+ Sync
.
use std::error::Error;
│ │ │ │ use std::mem;
│ │ │ │ use std::borrow::Cow;
│ │ │ │
│ │ │ │ let a_cow_str_error = Cow::from("a str error");
│ │ │ │ let a_boxed_error = Box::<dyn Error + Send + Sync>::from(a_cow_str_error);
│ │ │ │ assert!(
│ │ │ │ mem::size_of::<Box<dyn Error + Send + Sync>>() == mem::size_of_val(&a_boxed_error))
Converts a type of Error
into a box of dyn Error
.
use std::error::Error;
│ │ │ │ use std::fmt;
│ │ │ │ use std::mem;
│ │ │ │
│ │ │ │ #[derive(Debug)]
│ │ │ │ struct AnError;
│ │ │ │ @@ -1041,16 +1041,16 @@
│ │ │ │
│ │ │ │ impl Error for AnError {}
│ │ │ │
│ │ │ │ let an_error = AnError;
│ │ │ │ assert!(0 == mem::size_of_val(&an_error));
│ │ │ │ let a_boxed_error = Box::<dyn Error>::from(an_error);
│ │ │ │ assert!(mem::size_of::<Box<dyn Error>>() == mem::size_of_val(&a_boxed_error))
Converts a type of Error
+ Send
+ Sync
into a box of
│ │ │ │ +dyn Error
+ Send
+ Sync
.
use std::error::Error;
│ │ │ │ use std::fmt;
│ │ │ │ use std::mem;
│ │ │ │
│ │ │ │ #[derive(Debug)]
│ │ │ │ struct AnError;
│ │ │ │ @@ -1068,287 +1068,287 @@
│ │ │ │ unsafe impl Sync for AnError {}
│ │ │ │
│ │ │ │ let an_error = AnError;
│ │ │ │ assert!(0 == mem::size_of_val(&an_error));
│ │ │ │ let a_boxed_error = Box::<dyn Error + Send + Sync>::from(an_error);
│ │ │ │ assert!(
│ │ │ │ mem::size_of::<Box<dyn Error + Send + Sync>>() == mem::size_of_val(&a_boxed_error))
Converts a String
into a box of dyn Error
+ Send
+ Sync
.
use std::error::Error;
│ │ │ │ use std::mem;
│ │ │ │
│ │ │ │ let a_string_error = "a string error".to_string();
│ │ │ │ let a_boxed_error = Box::<dyn Error + Send + Sync>::from(a_string_error);
│ │ │ │ assert!(
│ │ │ │ mem::size_of::<Box<dyn Error + Send + Sync>>() == mem::size_of_val(&a_boxed_error))
u128
into this hasher.usize
into this hasher.i128
into this hasher.isize
into this hasher.n
th element of the iterator. Read moreu128
into this hasher.usize
into this hasher.i128
into this hasher.isize
into this hasher.n
th element of the iterator. Read moreiter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreAttempts to convert a Box<[T]>
into a Box<[T; N]>
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreAttempts to convert a Box<[T]>
into a Box<[T; N]>
.
The conversion occurs in-place and does not require a │ │ │ │ new memory allocation.
│ │ │ │Returns the old Box<[T]>
in the Err
variant if
│ │ │ │ boxed_slice.len()
does not equal N
.
Attempts to convert a Vec<T>
into a Box<[T; N]>
.
Like Vec::into_boxed_slice
, this is in-place if vec.capacity() == N
,
│ │ │ │ but will require a reallocation otherwise.
Returns the original Vec<T>
in the Err
variant if
│ │ │ │ boxed_slice.len()
does not equal N
.
This can be used with vec!
to create an array on the heap:
This implementation is required to make sure that the &Box<[I]>: IntoIterator
│ │ │ │ +
This implementation is required to make sure that the &Box<[I]>: IntoIterator
│ │ │ │ implementation doesn’t overlap with IntoIterator for T where T: Iterator
blanket.
This implementation is required to make sure that the &mut Box<[I]>: IntoIterator
│ │ │ │ +
This implementation is required to make sure that the &mut Box<[I]>: IntoIterator
│ │ │ │ implementation doesn’t overlap with IntoIterator for T where T: Iterator
blanket.
This implementation is required to make sure that the Box<[I]>: IntoIterator
│ │ │ │ +
This implementation is required to make sure that the Box<[I]>: IntoIterator
│ │ │ │ implementation doesn’t overlap with IntoIterator for T where T: Iterator
blanket.
async_iterator
#79024)async_iterator
#79024)async_iterator
#79024)self
into an async iteratorpattern
#27721)pattern
#27721)self
and the haystack
to search in.pattern
#27721)pattern
#27721)pattern
#27721)pattern
#27721)async_iterator
#79024)async_iterator
#79024)async_iterator
#79024)self
into an async iteratorpattern
#27721)pattern
#27721)self
and the haystack
to search in.pattern
#27721)pattern
#27721)pattern
#27721)pattern
#27721)pattern
#27721)pub struct ThinBox<T: ?Sized> { /* private fields */ }
thin_box
#92791)ThinBox.
│ │ │ │ +pub struct ThinBox<T: ?Sized> { /* private fields */ }
thin_box
#92791)ThinBox.
│ │ │ │A thin pointer for heap allocation, regardless of T.
│ │ │ │#![feature(thin_box)]
│ │ │ │ use std::boxed::ThinBox;
│ │ │ │
│ │ │ │ let five = ThinBox::new(5);
│ │ │ │ let thin_slice = ThinBox::<[i32]>::new_unsize([1, 2, 3, 4]);
│ │ │ │
│ │ │ │ use std::mem::{size_of, size_of_val};
│ │ │ │ let size_of_ptr = size_of::<*const ()>();
│ │ │ │ assert_eq!(size_of_ptr, size_of_val(&five));
│ │ │ │ assert_eq!(size_of_ptr, size_of_val(&thin_slice));
thin_box
#92791)Moves a type to the heap with its Metadata
stored in the heap allocation instead of on
│ │ │ │ +
thin_box
#92791)Moves a type to the heap with its Metadata
stored in the heap allocation instead of on
│ │ │ │ +
thin_box
#92791)thin_box
#92791)Moves a type to the heap with its Metadata
stored in the heap allocation instead of on
│ │ │ │ +
ThinBox<T>
is Send
if T
is Send
because the data is owned.
ThinBox<T>
is Sync
if T
is Sync
because the data is owned.
ThinBox<T>
is Send
if T
is Send
because the data is owned.
ThinBox<T>
is Sync
if T
is Sync
because the data is owned.
pub struct BinaryHeap<T, A: Allocator = Global> { /* private fields */ }
A priority queue implemented with a binary heap.
│ │ │ │This will be a max-heap.
│ │ │ │It is a logic error for an item to be modified in such a way that the
│ │ │ │ -item’s ordering relative to any other item, as determined by the Ord
│ │ │ │ +item’s ordering relative to any other item, as determined by the Ord
│ │ │ │ trait, changes while it is in the heap. This is normally only possible
│ │ │ │ through interior mutability, global state, I/O, or unsafe code. The
│ │ │ │ behavior resulting from such a logic error is not specified, but will
│ │ │ │ be encapsulated to the BinaryHeap
that observed the logic error and not
│ │ │ │ result in undefined behavior. This could include panics, incorrect results,
│ │ │ │ aborts, memory leaks, and non-termination.
As long as no elements change their relative order while being in the heap │ │ │ │ @@ -56,15 +56,15 @@ │ │ │ │ assert!(heap.is_empty())
A BinaryHeap
with a known list of items can be initialized from an array:
Either core::cmp::Reverse
or a custom Ord
implementation can be used to
│ │ │ │ +
Either core::cmp::Reverse
or a custom Ord
implementation can be used to
│ │ │ │ make BinaryHeap
a min-heap. This makes heap.pop()
return the smallest
│ │ │ │ value instead of the greatest one.
use std::collections::BinaryHeap;
│ │ │ │ use std::cmp::Reverse;
│ │ │ │
│ │ │ │ let mut heap = BinaryHeap::new();
│ │ │ │ @@ -81,55 +81,55 @@
│ │ │ │ assert_eq!(heap.pop(), None);
The value for push
is an expected cost; the method documentation gives a
│ │ │ │ more detailed analysis.
Creates an empty BinaryHeap
as a max-heap.
Creates an empty BinaryHeap
as a max-heap.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -Creates an empty BinaryHeap
with at least the specified capacity.
Creates an empty BinaryHeap
with at least the specified capacity.
The binary heap will be able to hold at least capacity
elements without
│ │ │ │ reallocating. This method is allowed to allocate for more elements than
│ │ │ │ capacity
. If capacity
is 0, the binary heap will not allocate.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -allocator_api
#32838)Creates an empty BinaryHeap
as a max-heap, using A
as allocator.
allocator_api
#32838)Creates an empty BinaryHeap
as a max-heap, using A
as allocator.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -allocator_api
#32838)Creates an empty BinaryHeap
with at least the specified capacity, using A
as allocator.
allocator_api
#32838)Creates an empty BinaryHeap
with at least the specified capacity, using A
as allocator.
The binary heap will be able to hold at least capacity
elements without
│ │ │ │ reallocating. This method is allowed to allocate for more elements than
│ │ │ │ capacity
. If capacity
is 0, the binary heap will not allocate.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -Returns a mutable reference to the greatest item in the binary heap, or │ │ │ │ +
Returns a mutable reference to the greatest item in the binary heap, or
│ │ │ │ None
if it is empty.
Note: If the PeekMut
value is leaked, some heap elements might get
│ │ │ │ leaked along with it, but the remaining elements will remain a valid
│ │ │ │ heap.
Basic usage:
│ │ │ │ │ │ │ │ @@ -144,15 +144,15 @@ │ │ │ │ let mut val = heap.peek_mut().unwrap(); │ │ │ │ *val = 0; │ │ │ │ } │ │ │ │ assert_eq!(heap.peek(), Some(&2));If the item is modified then the worst case time complexity is O(log(n)), │ │ │ │ otherwise it’s O(1).
│ │ │ │ -Removes the greatest item from the binary heap and returns it, or None
if it
│ │ │ │ +
Removes the greatest item from the binary heap and returns it, or None
if it
│ │ │ │ is empty.
Basic usage:
│ │ │ │ │ │ │ │use std::collections::BinaryHeap;
│ │ │ │ let mut heap = BinaryHeap::from([1, 3]);
│ │ │ │
│ │ │ │ @@ -229,15 +229,15 @@
│ │ │ │
│ │ │ │ let mut heap = BinaryHeap::from([1, 2, 3, 4, 5]);
│ │ │ │ assert_eq!(heap.len(), 5);
│ │ │ │
│ │ │ │ drop(heap.drain_sorted()); // removes all elements in heap order
│ │ │ │ assert_eq!(heap.len(), 0);
Retains only the elements specified by the predicate.
│ │ │ │In other words, remove all elements e
for which f(&e)
returns
│ │ │ │ false
. The elements are visited in unsorted (and unspecified) order.
Basic usage:
│ │ │ │ │ │ │ │use std::collections::BinaryHeap;
│ │ │ │
│ │ │ │ @@ -264,72 +264,72 @@
│ │ │ │ Basic usage:
│ │ │ │
│ │ │ │
│ │ │ │ -
Returns the greatest item in the binary heap, or None
if it is empty.
Returns the greatest item in the binary heap, or None
if it is empty.
Basic usage:
│ │ │ │ │ │ │ │use std::collections::BinaryHeap;
│ │ │ │ let mut heap = BinaryHeap::new();
│ │ │ │ assert_eq!(heap.peek(), None);
│ │ │ │
│ │ │ │ heap.push(1);
│ │ │ │ heap.push(5);
│ │ │ │ heap.push(2);
│ │ │ │ assert_eq!(heap.peek(), Some(&5));
│ │ │ │
Cost is O(1) in the worst case.
│ │ │ │ -Returns the number of elements the binary heap can hold without reallocating.
│ │ │ │ +Returns the number of elements the binary heap can hold without reallocating.
│ │ │ │Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -Reserves the minimum capacity for at least additional
elements more than
│ │ │ │ +
Reserves the minimum capacity for at least additional
elements more than
│ │ │ │ the current length. Unlike reserve
, this will not
│ │ │ │ deliberately over-allocate to speculatively avoid frequent allocations.
│ │ │ │ After calling reserve_exact
, capacity will be greater than or equal to
│ │ │ │ self.len() + additional
. Does nothing if the capacity is already
│ │ │ │ sufficient.
Panics if the new capacity overflows usize
.
Panics if the new capacity overflows usize
.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -Reserves capacity for at least additional
elements more than the
│ │ │ │ +
Reserves capacity for at least additional
elements more than the
│ │ │ │ current length. The allocator may reserve more space to speculatively
│ │ │ │ avoid frequent allocations. After calling reserve
,
│ │ │ │ capacity will be greater than or equal to self.len() + additional
.
│ │ │ │ Does nothing if capacity is already sufficient.
Panics if the new capacity overflows usize
.
Panics if the new capacity overflows usize
.
Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │Tries to reserve the minimum capacity for at least additional
elements
│ │ │ │ + additional: usize,
│ │ │ │ +) -> Result<(), TryReserveError>
Tries to reserve the minimum capacity for at least additional
elements
│ │ │ │ more than the current length. Unlike try_reserve
, this will not
│ │ │ │ deliberately over-allocate to speculatively avoid frequent allocations.
│ │ │ │ After calling try_reserve_exact
, capacity will be greater than or
│ │ │ │ equal to self.len() + additional
if it returns Ok(())
.
│ │ │ │ Does nothing if the capacity is already sufficient.
Note that the allocator may give the collection more space than it │ │ │ │ requests. Therefore, capacity can not be relied upon to be precisely │ │ │ │ @@ -348,15 +348,15 @@ │ │ │ │ heap.try_reserve_exact(data.len())?; │ │ │ │ │ │ │ │ // Now we know this can't OOM in the middle of our complex work │ │ │ │ heap.extend(data.iter()); │ │ │ │ │ │ │ │ Ok(heap.pop()) │ │ │ │ }
Tries to reserve capacity for at least additional
elements more than the
│ │ │ │ +
Tries to reserve capacity for at least additional
elements more than the
│ │ │ │ current length. The allocator may reserve more space to speculatively
│ │ │ │ avoid frequent allocations. After calling try_reserve
, capacity will be
│ │ │ │ greater than or equal to self.len() + additional
if it returns
│ │ │ │ Ok(())
. Does nothing if capacity is already sufficient. This method
│ │ │ │ preserves the contents even if an error occurs.
If the capacity overflows, or the allocator reports a failure, then an error │ │ │ │ @@ -382,26 +382,26 @@ │ │ │ │ │ │ │ │
│ │ │ │ -Discards capacity with a lower bound.
│ │ │ │ +Discards capacity with a lower bound.
│ │ │ │The capacity will remain at least as large as both the length │ │ │ │ and the supplied value.
│ │ │ │If the current capacity is less than the lower limit, this is a no-op.
│ │ │ │Returns a slice of all values in the underlying vector, in arbitrary │ │ │ │ +
Returns a slice of all values in the underlying vector, in arbitrary │ │ │ │ order.
│ │ │ │Basic usage:
│ │ │ │ │ │ │ │use std::collections::BinaryHeap;
│ │ │ │ use std::io::{self, Write};
│ │ │ │
│ │ │ │ @@ -417,24 +417,24 @@
│ │ │ │ let heap = BinaryHeap::from([1, 2, 3, 4, 5, 6, 7]);
│ │ │ │ let vec = heap.into_vec();
│ │ │ │
│ │ │ │ // Will print in some order
│ │ │ │ for x in vec {
│ │ │ │ println!("{x}");
│ │ │ │ }
allocator_api
#32838)Returns a reference to the underlying allocator.
│ │ │ │ -allocator_api
#32838)Returns a reference to the underlying allocator.
│ │ │ │ +Returns the length of the binary heap.
│ │ │ │Basic usage:
│ │ │ │ │ │ │ │ │ │ │ │ -Checks if the binary heap is empty.
│ │ │ │Basic usage:
│ │ │ │ │ │ │ │use std::collections::BinaryHeap;
│ │ │ │ let mut heap = BinaryHeap::new();
│ │ │ │
│ │ │ │ assert!(heap.is_empty());
│ │ │ │ @@ -470,63 +470,63 @@
│ │ │ │ let mut heap = BinaryHeap::from([1, 3]);
│ │ │ │
│ │ │ │ assert!(!heap.is_empty());
│ │ │ │
│ │ │ │ heap.clear();
│ │ │ │
│ │ │ │ assert!(heap.is_empty());
Overwrites the contents of self
with a clone of the contents of source
.
Overwrites the contents of self
with a clone of the contents of source
.
This method is preferred over simply assigning source.clone()
to self
,
│ │ │ │ as it avoids reallocation if possible.
See Vec::clone_from()
for more details.
Creates an empty BinaryHeap<T>
.
extend_one
#72631)Creates an empty BinaryHeap<T>
.
extend_one
#72631)Converts a BinaryHeap<T>
into a Vec<T>
.
Converts a BinaryHeap<T>
into a Vec<T>
.
This conversion requires no data movement or allocation, and has │ │ │ │ constant time complexity.
│ │ │ │ -Converts a Vec<T>
into a BinaryHeap<T>
.
Converts a Vec<T>
into a BinaryHeap<T>
.
This conversion happens in-place, and has O(n) time complexity.
│ │ │ │ -pub struct Drain<'a, T: 'a, A: Allocator = Global> { /* private fields */ }
A draining iterator over the elements of a BinaryHeap
.
This struct
is created by BinaryHeap::drain()
. See its
│ │ │ │ documentation for more.
iter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ -elements starting from the back of the iterator. Read moreiter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ +elements starting from the back of the iterator. Read moreiter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)n
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_partition_in_place
#62543)iter_partition_in_place
#62543)true
precede all those that return false
.
│ │ │ │ -Returns the number of true
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moretrue
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreCalls U::from(self)
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreFrom<T> for U
chooses to do.
│ │ │ │ +pub struct DrainSorted<'a, T: Ord, A: Allocator = Global> { /* private fields */ }
binary_heap_drain_sorted
#59278)A draining iterator over the elements of a BinaryHeap
.
pub struct DrainSorted<'a, T: Ord, A: Allocator = Global> { /* private fields */ }
binary_heap_drain_sorted
#59278)A draining iterator over the elements of a BinaryHeap
.
This struct
is created by BinaryHeap::drain_sorted()
. See its
│ │ │ │ documentation for more.
iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreCalls U::from(self)
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreFrom<T> for U
chooses to do.
│ │ │ │ +pub struct IntoIter<T, A: Allocator = Global> { /* private fields */ }
An owning iterator over the elements of a BinaryHeap
.
This struct
is created by BinaryHeap::into_iter()
│ │ │ │ -(provided by the IntoIterator
trait). See its documentation for more.
Creates an empty binary_heap::IntoIter
.
IntoIterator
trait). See its documentation for more.
│ │ │ │ +iter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ -elements starting from the back of the iterator. Read moreiter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ +elements starting from the back of the iterator. Read moreiter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)n
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_partition_in_place
#62543)iter_partition_in_place
#62543)true
precede all those that return false
.
│ │ │ │ -Returns the number of true
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moretrue
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreCalls U::from(self)
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreFrom<T> for U
chooses to do.
│ │ │ │ +pub struct IntoIterSorted<T, A: Allocator = Global> { /* private fields */ }
binary_heap_into_iter_sorted
#59278)source
. Read morepub struct IntoIterSorted<T, A: Allocator = Global> { /* private fields */ }
binary_heap_into_iter_sorted
#59278)source
. Read moreiter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreCalls U::from(self)
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreFrom<T> for U
chooses to do.
│ │ │ │ +pub struct Iter<'a, T: 'a> { /* private fields */ }
An iterator over the elements of a BinaryHeap
.
This struct
is created by BinaryHeap::iter()
. See its
│ │ │ │ documentation for more.
iter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ -elements starting from the back of the iterator. Read moreiter_advance_by
#77404)n
elements. Read moren
th element from the end of the iterator. Read moreIterator::try_fold()
: it takes
│ │ │ │ +elements starting from the back of the iterator. Read moreiter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ -between adjacent items of the original iterator. Read morepeek
and peek_mut
methods
│ │ │ │ +) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>iter_next_chunk
#98326)N
values. Read moreiter_advance_by
#77404)n
elements. Read moren
th element of the iterator. Read moreiter_intersperse
#79524)separator
│ │ │ │ +between adjacent items of the original iterator. Read moren
elements. Read moren
elements, or fewer
│ │ │ │ -if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ -self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ -the windows during mapping overlap as well. Read moreiter_collect_into
#94780)n
elements. Read moren
elements, or fewer
│ │ │ │ +if the underlying iterator ends sooner. Read moreiter_map_windows
#87155)f
for each contiguous window of size N
over
│ │ │ │ +self
and returns an iterator over the outputs of f
. Like slice::windows()
,
│ │ │ │ +the windows during mapping overlap as well. Read moreiter_collect_into
#94780)iter_partition_in_place
#62543)iter_partition_in_place
#62543)true
precede all those that return false
.
│ │ │ │ -Returns the number of true
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moretrue
elements found. Read moreiter_is_partitioned
#62544)true
precede all those that return false
. Read moreiterator_try_reduce
#87053)iterator_try_reduce
#87053)try_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ -this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ + f: impl FnMut(&Self::Item) -> R,
│ │ │ │ +) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryTypetry_find
#63178)iter_array_chunks
#100450)N
elements of the iterator at a time. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read morePartialOrd
elements of
│ │ │ │ +this Iterator
with those of another. The comparison works like short-circuit
│ │ │ │ evaluation, returning a result without comparing the remaining elements.
│ │ │ │ -As soon as an order can be determined, the evaluation stops and a result is returned. Read moreiter_order_by
#64295)Iterator
with those
│ │ │ │ -of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ -less than those of another. Read moreIterator
are lexicographically
│ │ │ │ -less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ -greater than or equal to those of another. Read moreCalls U::from(self)
.
iter_order_by
#64295)Iterator
with those
│ │ │ │ +of another with respect to the specified comparison function. Read moreiter_order_by
#64295)Iterator
are lexicographically
│ │ │ │ +less than those of another. Read moreIterator
are lexicographically
│ │ │ │ +less or equal to those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than those of another. Read moreIterator
are lexicographically
│ │ │ │ +greater than or equal to those of another. Read moreFrom<T> for U
chooses to do.
│ │ │ │ +pub struct PeekMut<'a, T: 'a + Ord, A: Allocator = Global> { /* private fields */ }
Structure wrapping a mutable reference to the greatest item on a │ │ │ │ +
pub struct PeekMut<'a, T: 'a + Ord, A: Allocator = Global> { /* private fields */ }
Structure wrapping a mutable reference to the greatest item on a
│ │ │ │ BinaryHeap
.
This struct
is created by the peek_mut
method on BinaryHeap
. See
│ │ │ │ its documentation for more.
From<T> for U
chooses to do.
│ │ │ │ +pub enum Entry<'a, K: 'a, V: 'a, A: Allocator + Clone = Global> {
│ │ │ │ +Entry in alloc::collections::btree_map - Rust pub enum Entry<'a, K: 'a, V: 'a, A: Allocator + Clone = Global> {
│ │ │ │ Vacant(VacantEntry<'a, K, V, A>),
│ │ │ │ Occupied(OccupiedEntry<'a, K, V, A>),
│ │ │ │ }
Expand description
Variants§
§1.36.0Vacant(VacantEntry<'a, K, V, A>)
A vacant entry.
│ │ │ │ §1.36.0Occupied(OccupiedEntry<'a, K, V, A>)
An occupied entry.
│ │ │ │ -Implementations§
source§impl<'a, K: Ord, V, A: Allocator + Clone> Entry<'a, K, V, A>
Implementations§
source§impl<'a, K: Ord, V, A: Allocator + Clone> Entry<'a, K, V, A>
1.0.0 · sourcepub fn or_insert(self, default: V) -> &'a mut V
Ensures a value is in the entry by inserting the default if empty, and returns
│ │ │ │ a mutable reference to the value in the entry.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.0.0 · sourcepub fn or_insert_with<F: FnOnce() -> V>(self, default: F) -> &'a mut V
Ensures a value is in the entry by inserting the result of the default function if empty,
│ │ │ │ +
1.0.0 · sourcepub fn or_insert_with<F: FnOnce() -> V>(self, default: F) -> &'a mut V
Ensures a value is in the entry by inserting the result of the default function if empty,
│ │ │ │ and returns a mutable reference to the value in the entry.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.50.0 · sourcepub fn or_insert_with_key<F: FnOnce(&K) -> V>(self, default: F) -> &'a mut V
Ensures a value is in the entry by inserting, if empty, the result of the default function.
│ │ │ │ +1.50.0 · sourcepub fn or_insert_with_key<F: FnOnce(&K) -> V>(self, default: F) -> &'a mut V
Ensures a value is in the entry by inserting, if empty, the result of the default function.
│ │ │ │ This method allows for generating key-derived values for insertion by providing the default
│ │ │ │ function a reference to the key that was moved during the .entry(key)
method call.
│ │ │ │ The reference to the moved key is provided so that cloning or copying the key is
│ │ │ │ unnecessary, unlike with .or_insert_with(|| ... )
.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -1.10.0 · sourcepub fn key(&self) -> &K
Returns a reference to this entry’s key.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ 1.26.0 · sourcepub fn and_modify<F>(self, f: F) -> Self
Provides in-place mutable access to an occupied entry before any
│ │ │ │ potential inserts into the map.
│ │ │ │ §Examples
│ │ │ │ use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut map: BTreeMap<&str, usize> = BTreeMap::new();
│ │ │ │
│ │ │ │ map.entry("poneyland")
│ │ │ │ @@ -57,40 +57,40 @@
│ │ │ │ .or_insert(42);
│ │ │ │ assert_eq!(map["poneyland"], 42);
│ │ │ │
│ │ │ │ map.entry("poneyland")
│ │ │ │ .and_modify(|e| { *e += 1 })
│ │ │ │ .or_insert(42);
│ │ │ │ assert_eq!(map["poneyland"], 43);
│ │ │ │ -source§impl<'a, K: Ord, V: Default, A: Allocator + Clone> Entry<'a, K, V, A>
1.28.0 · sourcepub fn or_default(self) -> &'a mut V
Ensures a value is in the entry by inserting the default value if empty,
│ │ │ │ +
source§impl<'a, K: Ord, V: Default, A: Allocator + Clone> Entry<'a, K, V, A>
1.28.0 · sourcepub fn or_default(self) -> &'a mut V
Ensures a value is in the entry by inserting the default value if empty,
│ │ │ │ and returns a mutable reference to the value in the entry.
│ │ │ │ §Examples
│ │ │ │
│ │ │ │ -Trait Implementations§
Auto Trait Implementations§
§impl<'a, K, V, A> Freeze for Entry<'a, K, V, A>
§impl<'a, K, V, A> RefUnwindSafe for Entry<'a, K, V, A>
§impl<'a, K, V, A> Send for Entry<'a, K, V, A>
§impl<'a, K, V, A> Sync for Entry<'a, K, V, A>
§impl<'a, K, V, A> Unpin for Entry<'a, K, V, A>
§impl<'a, K, V, A = Global> !UnwindSafe for Entry<'a, K, V, A>
Blanket Implementations§
Trait Implementations§
Auto Trait Implementations§
§impl<'a, K, V, A> Freeze for Entry<'a, K, V, A>
§impl<'a, K, V, A> RefUnwindSafe for Entry<'a, K, V, A>
§impl<'a, K, V, A> Send for Entry<'a, K, V, A>
§impl<'a, K, V, A> Sync for Entry<'a, K, V, A>
§impl<'a, K, V, A> Unpin for Entry<'a, K, V, A>
§impl<'a, K, V, A = Global> !UnwindSafe for Entry<'a, K, V, A>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
│ │ │ │ + T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
│ │ │ │ +From<T> for U
chooses to do.
│ │ │ │ +
pub struct BTreeMap<K, V, A: Allocator + Clone = Global> { /* private fields */ }
An ordered map based on a B-Tree.
│ │ │ │ +pub struct BTreeMap<K, V, A: Allocator + Clone = Global> { /* private fields */ }
An ordered map based on a B-Tree.
│ │ │ │B-Trees represent a fundamental compromise between cache-efficiency and actually minimizing │ │ │ │ the amount of work performed in a search. In theory, a binary search tree (BST) is the optimal │ │ │ │ choice for a sorted map, as a perfectly balanced BST performs the theoretical minimum amount of │ │ │ │ comparisons necessary to find an element (log2n). However, in practice the way this │ │ │ │ is done is very inefficient for modern computer architectures. In particular, every element │ │ │ │ is stored in its own individually heap-allocated node. This means that every single insertion │ │ │ │ triggers a heap-allocation, and every single comparison should be a cache-miss. Since these │ │ │ │ @@ -18,16 +18,16 @@ │ │ │ │
Currently, our implementation simply performs naive linear search. This provides excellent │ │ │ │ performance on small nodes of elements which are cheap to compare. However in the future we │ │ │ │ would like to further explore choosing the optimal search strategy based on the choice of B, │ │ │ │ and possibly other factors. Using linear search, searching for a random element is expected │ │ │ │ to take B * log(n) comparisons, which is generally worse than a BST. In practice, │ │ │ │ however, performance is excellent.
│ │ │ │It is a logic error for a key to be modified in such a way that the key’s ordering relative to
│ │ │ │ -any other key, as determined by the Ord
trait, changes while it is in the map. This is
│ │ │ │ -normally only possible through Cell
, RefCell
, global state, I/O, or unsafe code.
│ │ │ │ +any other key, as determined by the Ord
trait, changes while it is in the map. This is
│ │ │ │ +normally only possible through Cell
, RefCell
, global state, I/O, or unsafe code.
│ │ │ │ The behavior resulting from such a logic error is not specified, but will be encapsulated to the
│ │ │ │ BTreeMap
that observed the logic error and not result in undefined behavior. This could
│ │ │ │ include panics, incorrect results, aborts, memory leaks, and non-termination.
Iterators obtained from functions such as BTreeMap::iter
, BTreeMap::into_iter
, BTreeMap::values
, or
│ │ │ │ BTreeMap::keys
produce their items in order by key, and take worst-case logarithmic and
│ │ │ │ amortized constant time per item returned.
Clears the map, removing all elements.
│ │ │ │Returns a reference to the value corresponding to the key.
│ │ │ │The key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Returns the key-value pair corresponding to the supplied key.
│ │ │ │ +Returns the key-value pair corresponding to the supplied key.
│ │ │ │The supplied key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Returns the first key-value pair in the map. │ │ │ │ +
Returns the first key-value pair in the map. │ │ │ │ The key in this pair is the minimum key in the map.
│ │ │ │Returns the first entry in the map for in-place manipulation. │ │ │ │ +
Returns the first entry in the map for in-place manipulation. │ │ │ │ The key of this entry is the minimum key in the map.
│ │ │ │use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut map = BTreeMap::new();
│ │ │ │ map.insert(1, "a");
│ │ │ │ map.insert(2, "b");
│ │ │ │ if let Some(mut entry) = map.first_entry() {
│ │ │ │ if *entry.key() > 0 {
│ │ │ │ entry.insert("first");
│ │ │ │ }
│ │ │ │ }
│ │ │ │ assert_eq!(*map.get(&1).unwrap(), "first");
│ │ │ │ assert_eq!(*map.get(&2).unwrap(), "b");
Removes and returns the first element in the map. │ │ │ │ +
Removes and returns the first element in the map. │ │ │ │ The key of this element is the minimum key that was in the map.
│ │ │ │Draining elements in ascending order, while keeping a usable map each iteration.
│ │ │ │ │ │ │ │ │ │ │ │ -Returns the last key-value pair in the map. │ │ │ │ +
Returns the last key-value pair in the map. │ │ │ │ The key in this pair is the maximum key in the map.
│ │ │ │Returns the last entry in the map for in-place manipulation. │ │ │ │ +
Returns the last entry in the map for in-place manipulation. │ │ │ │ The key of this entry is the maximum key in the map.
│ │ │ │use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut map = BTreeMap::new();
│ │ │ │ map.insert(1, "a");
│ │ │ │ map.insert(2, "b");
│ │ │ │ if let Some(mut entry) = map.last_entry() {
│ │ │ │ if *entry.key() > 0 {
│ │ │ │ entry.insert("last");
│ │ │ │ }
│ │ │ │ }
│ │ │ │ assert_eq!(*map.get(&1).unwrap(), "a");
│ │ │ │ assert_eq!(*map.get(&2).unwrap(), "last");
Removes and returns the last element in the map. │ │ │ │ +
Removes and returns the last element in the map. │ │ │ │ The key of this element is the maximum key that was in the map.
│ │ │ │Draining elements in descending order, while keeping a usable map each iteration.
│ │ │ │ │ │ │ │ │ │ │ │ -Returns true
if the map contains a value for the specified key.
Returns true
if the map contains a value for the specified key.
The key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Returns a mutable reference to the value corresponding to the key.
│ │ │ │ +Returns a mutable reference to the value corresponding to the key.
│ │ │ │The key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Inserts a key-value pair into the map.
│ │ │ │ +Inserts a key-value pair into the map.
│ │ │ │If the map did not have this key present, None
is returned.
If the map did have this key present, the value is updated, and the old
│ │ │ │ value is returned. The key is not updated, though; this matters for
│ │ │ │ types that can be ==
without being identical. See the module-level
│ │ │ │ documentation for more.
map_try_insert
#82766)Tries to insert a key-value pair into the map, and returns │ │ │ │ +) -> Result<&mut V, OccupiedError<'_, K, V, A>>
map_try_insert
#82766)Tries to insert a key-value pair into the map, and returns │ │ │ │ a mutable reference to the value in the entry.
│ │ │ │If the map already had this key present, nothing is updated, and │ │ │ │ an error containing the occupied entry and the value is returned.
│ │ │ │#![feature(map_try_insert)]
│ │ │ │
│ │ │ │ use std::collections::BTreeMap;
│ │ │ │ @@ -299,55 +299,55 @@
│ │ │ │ let mut map = BTreeMap::new();
│ │ │ │ assert_eq!(map.try_insert(37, "a").unwrap(), &"a");
│ │ │ │
│ │ │ │ let err = map.try_insert(37, "b").unwrap_err();
│ │ │ │ assert_eq!(err.entry.key(), &37);
│ │ │ │ assert_eq!(err.entry.get(), &"a");
│ │ │ │ assert_eq!(err.value, "b");
Removes a key from the map, returning the value at the key if the key │ │ │ │ +
Removes a key from the map, returning the value at the key if the key │ │ │ │ was previously in the map.
│ │ │ │The key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Removes a key from the map, returning the stored key and value if the key │ │ │ │ +
Removes a key from the map, returning the stored key and value if the key │ │ │ │ was previously in the map.
│ │ │ │The key may be any borrowed form of the map’s key type, but the ordering │ │ │ │ on the borrowed form must match the ordering on the key type.
│ │ │ │Retains only the elements specified by the predicate.
│ │ │ │ + K: Ord, │ │ │ │ + F: FnMut(&K, &mut V) -> bool,Retains only the elements specified by the predicate.
│ │ │ │In other words, remove all pairs (k, v)
for which f(&k, &mut v)
returns false
.
│ │ │ │ The elements are visited in ascending key order.
Moves all elements from other
into self
, leaving other
empty.
If a key from other
is already present in self
, the respective
│ │ │ │ value from self
will be overwritten with the respective value from other
.
use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut a = BTreeMap::new();
│ │ │ │ a.insert(1, "a");
│ │ │ │ @@ -366,17 +366,17 @@
│ │ │ │
│ │ │ │ assert_eq!(a[&1], "a");
│ │ │ │ assert_eq!(a[&2], "b");
│ │ │ │ assert_eq!(a[&3], "d"); // Note: "c" has been overwritten.
│ │ │ │ assert_eq!(a[&4], "e");
│ │ │ │ assert_eq!(a[&5], "f");
Constructs a double-ended iterator over a sub-range of elements in the map. │ │ │ │ + T: Ord + ?Sized, │ │ │ │ + K: Borrow<T> + Ord, │ │ │ │ + R: RangeBounds<T>,
Constructs a double-ended iterator over a sub-range of elements in the map.
│ │ │ │ The simplest way is to use the range syntax min..max
, thus range(min..max)
will
│ │ │ │ yield elements from min (inclusive) to max (exclusive).
│ │ │ │ The range may also be entered as (Bound<T>, Bound<T>)
, so for example
│ │ │ │ range((Excluded(4), Included(10)))
will yield a left-exclusive, right-inclusive
│ │ │ │ range from 4 to 10.
Panics if range start > end
.
│ │ │ │ @@ -390,17 +390,17 @@
│ │ │ │ map.insert(5, "b");
│ │ │ │ map.insert(8, "c");
│ │ │ │ for (&key, &value) in map.range((Included(&4), Included(&8))) {
│ │ │ │ println!("{key}: {value}");
│ │ │ │ }
│ │ │ │ assert_eq!(Some((&5, &"b")), map.range(4..).next());
Constructs a mutable double-ended iterator over a sub-range of elements in the map. │ │ │ │ + T: Ord + ?Sized, │ │ │ │ + K: Borrow<T> + Ord, │ │ │ │ + R: RangeBounds<T>,
Constructs a mutable double-ended iterator over a sub-range of elements in the map.
│ │ │ │ The simplest way is to use the range syntax min..max
, thus range(min..max)
will
│ │ │ │ yield elements from min (inclusive) to max (exclusive).
│ │ │ │ The range may also be entered as (Bound<T>, Bound<T>)
, so for example
│ │ │ │ range((Excluded(4), Included(10)))
will yield a left-exclusive, right-inclusive
│ │ │ │ range from 4 to 10.
Panics if range start > end
.
│ │ │ │ @@ -413,31 +413,31 @@
│ │ │ │ for (_, balance) in map.range_mut("B".."Cheryl") {
│ │ │ │ *balance += 100;
│ │ │ │ }
│ │ │ │ for (name, balance) in &map {
│ │ │ │ println!("{name} => {balance}");
│ │ │ │ }
Gets the given key’s corresponding entry in the map for in-place manipulation.
│ │ │ │ + K: Ord,Gets the given key’s corresponding entry in the map for in-place manipulation.
│ │ │ │use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut count: BTreeMap<&str, usize> = BTreeMap::new();
│ │ │ │
│ │ │ │ // count the number of occurrences of letters in the vec
│ │ │ │ for x in ["a", "b", "a", "c", "a", "b"] {
│ │ │ │ count.entry(x).and_modify(|curr| *curr += 1).or_insert(1);
│ │ │ │ }
│ │ │ │
│ │ │ │ assert_eq!(count["a"], 3);
│ │ │ │ assert_eq!(count["b"], 2);
│ │ │ │ assert_eq!(count["c"], 1);
Splits the collection into two at the given key. Returns everything after the given key, │ │ │ │ +
Splits the collection into two at the given key. Returns everything after the given key, │ │ │ │ including the key.
│ │ │ │use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut a = BTreeMap::new();
│ │ │ │ a.insert(1, "a");
│ │ │ │ a.insert(2, "b");
│ │ │ │ @@ -453,16 +453,16 @@
│ │ │ │ assert_eq!(a[&1], "a");
│ │ │ │ assert_eq!(a[&2], "b");
│ │ │ │
│ │ │ │ assert_eq!(b[&3], "c");
│ │ │ │ assert_eq!(b[&17], "d");
│ │ │ │ assert_eq!(b[&41], "e");
btree_extract_if
#70530)Creates an iterator that visits all elements (key-value pairs) in │ │ │ │ + K: Ord, │ │ │ │ + F: FnMut(&K, &mut V) -> bool,
btree_extract_if
#70530)Creates an iterator that visits all elements (key-value pairs) in
│ │ │ │ ascending key order and uses a closure to determine if an element should
│ │ │ │ be removed. If the closure returns true
, the element is removed from
│ │ │ │ the map and yielded. If the closure returns false
, or panics, the
│ │ │ │ element remains in the map and will not be yielded.
The iterator also lets you mutate the value of each element in the │ │ │ │ closure, regardless of whether you choose to keep or remove it.
│ │ │ │If the returned ExtractIf
is not exhausted, e.g. because it is dropped without iterating
│ │ │ │ @@ -499,15 +499,15 @@
│ │ │ │
│ │ │ │ let mut a = BTreeMap::new();
│ │ │ │ a.insert(1, "hello");
│ │ │ │ a.insert(2, "goodbye");
│ │ │ │
│ │ │ │ let values: Vec<&str> = a.into_values().collect();
│ │ │ │ assert_eq!(values, ["hello", "goodbye"]);
Gets an iterator over the entries of the map, sorted by key.
│ │ │ │use std::collections::BTreeMap;
│ │ │ │
│ │ │ │ let mut map = BTreeMap::new();
│ │ │ │ map.insert(3, "c");
│ │ │ │ map.insert(2, "b");
│ │ │ │ map.insert(1, "a");
│ │ │ │ @@ -565,33 +565,33 @@
│ │ │ │ for value in a.values_mut() {
│ │ │ │ value.push_str("!");
│ │ │ │ }
│ │ │ │
│ │ │ │ let values: Vec<String> = a.values().cloned().collect();
│ │ │ │ assert_eq!(values, [String::from("hello!"),
│ │ │ │ String::from("goodbye!")]);
Returns the number of elements in the map.
│ │ │ │ +Returns the number of elements in the map.
│ │ │ │Returns true
if the map contains no elements.
Returns true
if the map contains no elements.
btree_cursors
#107540)Returns a Cursor
pointing at the gap before the smallest key
│ │ │ │ +
btree_cursors
#107540)Returns a Cursor
pointing at the gap before the smallest key
│ │ │ │ greater than the given bound.
Passing Bound::Included(x)
will return a cursor pointing to the
│ │ │ │ gap before the smallest key greater than or equal to x
.
Passing Bound::Excluded(x)
will return a cursor pointing to the
│ │ │ │ gap before the smallest key greater than x
.
Passing Bound::Unbounded
will return a cursor pointing to the
│ │ │ │ gap before the smallest key in the map.
btree_cursors
#107540)Returns a CursorMut
pointing at the gap before the smallest key
│ │ │ │ +
btree_cursors
#107540)Returns a CursorMut
pointing at the gap before the smallest key
│ │ │ │ greater than the given bound.
Passing Bound::Included(x)
will return a cursor pointing to the
│ │ │ │ gap before the smallest key greater than or equal to x
.
Passing Bound::Excluded(x)
will return a cursor pointing to the
│ │ │ │ gap before the smallest key greater than x
.
Passing Bound::Unbounded
will return a cursor pointing to the
│ │ │ │ gap before the smallest key in the map.
btree_cursors
#107540)Returns a Cursor
pointing at the gap after the greatest key
│ │ │ │ +
btree_cursors
#107540)Returns a Cursor
pointing at the gap after the greatest key
│ │ │ │ smaller than the given bound.
Passing Bound::Included(x)
will return a cursor pointing to the
│ │ │ │ gap after the greatest key smaller than or equal to x
.
Passing Bound::Excluded(x)
will return a cursor pointing to the
│ │ │ │ gap after the greatest key smaller than x
.
Passing Bound::Unbounded
will return a cursor pointing to the
│ │ │ │ gap after the greatest key in the map.
btree_cursors
#107540)Returns a CursorMut
pointing at the gap after the greatest key
│ │ │ │ +
btree_cursors
#107540)Returns a CursorMut
pointing at the gap after the greatest key
│ │ │ │ smaller than the given bound.
Passing Bound::Included(x)
will return a cursor pointing to the
│ │ │ │ gap after the greatest key smaller than or equal to x
.
Passing Bound::Excluded(x)
will return a cursor pointing to the
│ │ │ │ gap after the greatest key smaller than x
.
Passing Bound::Unbounded
will return a cursor pointing to the
│ │ │ │ gap after the greatest key in the map.
pub struct Cursor<'a, K: 'a, V: 'a> { /* private fields */ }
btree_cursors
#107540)A cursor over a BTreeMap
.
A Cursor
is like an iterator, except that it can freely seek back-and-forth.
Cursors always point to a gap between two elements in the map, and can │ │ │ │ operate on the two immediately adjacent elements.
│ │ │ │A Cursor
is created with the BTreeMap::lower_bound
and BTreeMap::upper_bound
methods.
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ element that it moved over.
│ │ │ │If the cursor is already at the end of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ the element that it moved over.
│ │ │ │If the cursor is already at the start of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ moving the cursor.
│ │ │ │If the cursor is at the end of the map then None
is returned.
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ without moving the cursor.
│ │ │ │If the cursor is at the start of the map then None
is returned.
Cursors always point to a gap between two elements in the map, and can │ │ │ │ operate on the two immediately adjacent elements.
│ │ │ │A CursorMut
is created with the BTreeMap::lower_bound_mut
and BTreeMap::upper_bound_mut
│ │ │ │ methods.
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ element that it moved over.
│ │ │ │If the cursor is already at the end of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ the element that it moved over.
│ │ │ │If the cursor is already at the start of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ moving the cursor.
│ │ │ │If the cursor is at the end of the map then None
is returned.
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ without moving the cursor.
│ │ │ │If the cursor is at the start of the map then None
is returned.
btree_cursors
#107540)Returns a read-only cursor pointing to the same location as the
│ │ │ │ CursorMut
.
The lifetime of the returned Cursor
is bound to that of the
│ │ │ │ CursorMut
, which means it cannot outlive the CursorMut
and that the
│ │ │ │ CursorMut
is frozen for the lifetime of the Cursor
.
Since this cursor allows mutating keys, you must ensure that the BTreeMap
│ │ │ │ invariants are maintained. Specifically:
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the │ │ │ │ +
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap after the │ │ │ │ newly inserted element.
│ │ │ │You must ensure that the BTreeMap
invariants are maintained.
│ │ │ │ Specifically:
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the
│ │ │ │ +) -> Result<(), UnorderedKeyError>🔬This is a nightly-only experimental API. (btree_cursors
#107540)
Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap before the │ │ │ │ newly inserted element.
│ │ │ │If the inserted key is not greater than the key before the cursor
│ │ │ │ (if any), or if it not less than the key after the cursor (if any),
│ │ │ │ then an UnorderedKeyError
is returned since this would
│ │ │ │ -invalidate the Ord
invariant between the keys of the map.
Ord
invariant between the keys of the map.
│ │ │ │ btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the
│ │ │ │ +) -> Result<(), UnorderedKeyError>🔬This is a nightly-only experimental API. (btree_cursors
#107540)
Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap after the │ │ │ │ newly inserted element.
│ │ │ │If the inserted key is not greater than the key before the cursor
│ │ │ │ (if any), or if it not less than the key after the cursor (if any),
│ │ │ │ then an UnorderedKeyError
is returned since this would
│ │ │ │ -invalidate the Ord
invariant between the keys of the map.
btree_cursors
#107540)Removes the next element from the BTreeMap
.
Ord
invariant between the keys of the map.
│ │ │ │ +btree_cursors
#107540)Removes the next element from the BTreeMap
.
The element that was removed is returned. The cursor position is │ │ │ │ unchanged (before the removed element).
│ │ │ │ -btree_cursors
#107540)Removes the preceding element from the BTreeMap
.
btree_cursors
#107540)Removes the preceding element from the BTreeMap
.
The element that was removed is returned. The cursor position is │ │ │ │ unchanged (after the removed element).
│ │ │ │ -From<T> for U
chooses to do.
│ │ │ │ +Since this cursor allows mutating keys, you must ensure that the BTreeMap
│ │ │ │ invariants are maintained. Specifically:
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the next gap, returning the key and value of the │ │ │ │ element that it moved over.
│ │ │ │If the cursor is already at the end of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ +
btree_cursors
#107540)Advances the cursor to the previous gap, returning the key and value of │ │ │ │ the element that it moved over.
│ │ │ │If the cursor is already at the start of the map then None
is returned
│ │ │ │ and the cursor is not moved.
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the next element without │ │ │ │ moving the cursor.
│ │ │ │If the cursor is at the end of the map then None
is returned.
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ +
btree_cursors
#107540)Returns a reference to the key and value of the previous element │ │ │ │ without moving the cursor.
│ │ │ │If the cursor is at the start of the map then None
is returned.
btree_cursors
#107540)Returns a read-only cursor pointing to the same location as the
│ │ │ │ CursorMutKey
.
The lifetime of the returned Cursor
is bound to that of the
│ │ │ │ CursorMutKey
, which means it cannot outlive the CursorMutKey
and that the
│ │ │ │ CursorMutKey
is frozen for the lifetime of the Cursor
.
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the │ │ │ │ +
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap before the │ │ │ │ newly inserted element.
│ │ │ │You must ensure that the BTreeMap
invariants are maintained.
│ │ │ │ Specifically:
btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the
│ │ │ │ +) -> Result<(), UnorderedKeyError>🔬This is a nightly-only experimental API. (btree_cursors
#107540)
Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap before the │ │ │ │ newly inserted element.
│ │ │ │If the inserted key is not greater than the key before the cursor
│ │ │ │ (if any), or if it not less than the key after the cursor (if any),
│ │ │ │ then an UnorderedKeyError
is returned since this would
│ │ │ │ -invalidate the Ord
invariant between the keys of the map.
Ord
invariant between the keys of the map.
│ │ │ │ btree_cursors
#107540)Inserts a new key-value pair into the map in the gap that the
│ │ │ │ +) -> Result<(), UnorderedKeyError>🔬This is a nightly-only experimental API. (btree_cursors
#107540)
Inserts a new key-value pair into the map in the gap that the │ │ │ │ cursor is currently pointing to.
│ │ │ │After the insertion the cursor will be pointing at the gap after the │ │ │ │ newly inserted element.
│ │ │ │If the inserted key is not greater than the key before the cursor
│ │ │ │ (if any), or if it not less than the key after the cursor (if any),
│ │ │ │ then an UnorderedKeyError
is returned since this would
│ │ │ │ -invalidate the Ord
invariant between the keys of the map.
btree_cursors
#107540)Removes the next element from the BTreeMap
.
Ord
invariant between the keys of the map.
│ │ │ │ +btree_cursors
#107540)Removes the next element from the BTreeMap
.
The element that was removed is returned. The cursor position is │ │ │ │ unchanged (before the removed element).
│ │ │ │ -btree_cursors
#107540)Removes the preceding element from the BTreeMap
.
btree_cursors
#107540)Removes the preceding element from the BTreeMap
.
The element that was removed is returned. The cursor position is │ │ │ │ unchanged (after the removed element).
│ │ │ │ -