1.0.0[−][src]Trait std::convert::AsMut
Used to do a cheap mutable-to-mutable reference conversion.
This trait is similar to AsRef but used for converting between mutable
references. If you need to do a costly conversion it is better to
implement From with type &mut T or write a custom function.
Note: This trait must not fail. If the conversion can fail, use a
dedicated method which returns an Option<T> or a Result<T, E>.
Generic Implementations
AsMutauto-dereferences if the inner type is a mutable reference (e.g.:foo.as_mut()will work the same iffoohas type&mut Fooor&mut &mut Foo)
Examples
Using AsMut as trait bound for a generic function we can accept all mutable references
that can be converted to type &mut T. Because Box<T> implements AsMut<T> we can
write a function add_one that takes all arguments that can be converted to &mut u64.
Because Box<T> implements AsMut<T>, add_one accepts arguments of type
&mut Box<u64> as well:
fn add_one<T: AsMut<u64>>(num: &mut T) { *num.as_mut() += 1; } let mut boxed_num = Box::new(0); add_one(&mut boxed_num); assert_eq!(*boxed_num, 1);Run
Required methods
Loading content...Implementors
impl AsMut<str> for String[src]
impl<'_, T, U> AsMut<U> for &'_ mut T where
T: AsMut<U> + ?Sized,
U: ?Sized, [src]
T: AsMut<U> + ?Sized,
U: ?Sized,
impl<T> AsMut<[T]> for [T][src]
impl<T> AsMut<[T]> for Vec<T>[src]
impl<T> AsMut<Vec<T>> for Vec<T>[src]
impl<T> AsMut<T> for Box<T> where
T: ?Sized, [src]
T: ?Sized,
impl<const N: usize, T> AsMut<[T]> for [T; N] where
[T; N]: LengthAtMost32, [src]
[T; N]: LengthAtMost32,