本文簡要介紹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。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。