本文簡要介紹rust語言中 Function std::ptr::write_volatile
的用法。
用法
pub unsafe fn write_volatile<T>(dst: *mut T, src: T)
使用給定值執行內存位置的易失性寫入,而不讀取或刪除舊值。
易失性操作旨在作用於 I/O 內存,並保證編譯器不會在其他易失性操作中忽略或重新排序。
write_volatile
不會刪除 dst
的內容。這是安全的,但它可能會泄漏分配或資源,因此應注意不要覆蓋應刪除的對象。
此外,它不會刪除 src
。從語義上講,src
被移動到 dst
指向的位置。
注意
Rust 目前沒有嚴格且正式定義的內存模型,因此 “volatile” 的精確語義可能會隨著時間的推移而發生變化。話雖這麽說,語義幾乎總是最終與 C11's definition of volatile 非常相似。
編譯器不應更改易失性內存操作的相對順序或數量。但是,對零大小類型的易失性內存操作(例如,如果將零大小類型傳遞給 write_volatile
)是無操作的,可能會被忽略。
安全性
如果違反以下任何條件,則行為未定義:
-
對於寫入,
dst
必須是 valid。 -
dst
必須正確對齊。
請注意,即使 T
的大小為 0
,指針也必須非空且正確對齊。
就像在 C 中一樣,一個操作是否是 volatile 與涉及來自多個線程的並發訪問的問題沒有任何關係。在這方麵,易失性訪問的行為與非原子訪問完全相同。特別是,write_volatile
與同一位置上的任何其他操作(讀取或寫入)之間的競爭是未定義的行為。
例子
基本用法:
let mut x = 0;
let y = &mut x as *mut i32;
let z = 12;
unsafe {
std::ptr::write_volatile(y, z);
assert_eq!(std::ptr::read_volatile(y), 12);
}
相關用法
- Rust write_unaligned用法及代碼示例
- Rust write_bytes用法及代碼示例
- Rust write用法及代碼示例
- Rust writeln用法及代碼示例
- Rust UdpSocket.set_multicast_loop_v6用法及代碼示例
- Rust i64.overflowing_add_unsigned用法及代碼示例
- Rust Box.downcast用法及代碼示例
- Rust BTreeMap.last_key_value用法及代碼示例
- Rust str.make_ascii_uppercase用法及代碼示例
- Rust u128.checked_pow用法及代碼示例
- Rust usize.wrapping_mul用法及代碼示例
- Rust AtomicU8.fetch_sub用法及代碼示例
- Rust PanicInfo.payload用法及代碼示例
- Rust MaybeUninit.assume_init_mut用法及代碼示例
- Rust String.try_reserve用法及代碼示例
- Rust Mutex.new用法及代碼示例
- Rust f32.exp用法及代碼示例
- Rust Result.unwrap_or_else用法及代碼示例
- Rust slice.sort_unstable_by_key用法及代碼示例
- Rust Formatter.precision用法及代碼示例
- Rust i128.log2用法及代碼示例
- Rust OsStr.to_ascii_uppercase用法及代碼示例
- Rust f32.hypot用法及代碼示例
- Rust RefCell.try_borrow_unguarded用法及代碼示例
- Rust i16.log10用法及代碼示例
注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 Function std::ptr::write_volatile。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。