本文简要介绍rust语言中 std::ptr::NonNull.as_mut
的用法。
用法
pub unsafe fn as_mut<'a>(&mut self) -> &'a mut T
返回对该值的唯一引用。如果该值可能未初始化,则必须改用 as_uninit_mut
。
对于共享副本,请参阅 as_ref
。
安全性
调用此方法时,您必须确保满足以下所有条件:
-
指针必须正确对齐。
-
它必须是the module documentation 中定义的意义上的“dereferencable”。
-
指针必须指向
T
的初始化实例。 -
您必须强制执行 Rust 的别名规则,因为返回的生命周期
'a
是任意选择的,不一定反映数据的实际生命周期。特别是,在此生命周期内,指针指向的内存不得通过任何其他指针访问(读取或写入)。
即使此方法的结果未使用,这也适用! (关于被初始化的部分还没有完全确定,但在确定之前,唯一安全的方法是确保它们确实被初始化。)
例子
use std::ptr::NonNull;
let mut x = 0u32;
let mut ptr = NonNull::new(&mut x).expect("null pointer");
let x_ref = unsafe { ptr.as_mut() };
assert_eq!(*x_ref, 0);
*x_ref += 2;
assert_eq!(*x_ref, 2);
相关用法
- Rust NonNull.as_mut_ptr用法及代码示例
- Rust NonNull.as_uninit_slice_mut用法及代码示例
- Rust NonNull.as_ptr用法及代码示例
- Rust NonNull.as_non_null_ptr用法及代码示例
- Rust NonNull.as_ref用法及代码示例
- Rust NonNull.len用法及代码示例
- Rust NonNull.slice_from_raw_parts用法及代码示例
- Rust NonNull.cast用法及代码示例
- Rust NonNull.new_unchecked用法及代码示例
- Rust NonNull.get_unchecked_mut用法及代码示例
- Rust NonNull.new用法及代码示例
- Rust NonNull.dangling用法及代码示例
- Rust NonZeroU128.checked_pow用法及代码示例
- Rust NonZeroUsize.checked_next_power_of_two用法及代码示例
- Rust NonZeroI128.saturating_pow用法及代码示例
- Rust NonZeroI64.wrapping_abs用法及代码示例
- Rust NonZeroU64.checked_mul用法及代码示例
- Rust NonZeroU16.saturating_pow用法及代码示例
- Rust NonZeroU8.checked_add用法及代码示例
- Rust NonZeroUsize.checked_pow用法及代码示例
- Rust NonZeroU8.unchecked_add用法及代码示例
- Rust NonZeroUsize.leading_zeros用法及代码示例
- Rust NonZeroI32.trailing_zeros用法及代码示例
- Rust NonZeroI8.saturating_pow用法及代码示例
- Rust NonZeroIsize.wrapping_abs用法及代码示例
注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 std::ptr::NonNull.as_mut。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。