本文簡要介紹rust語言中 Macro core::writeln
的用法。
用法
macro_rules! writeln {
($dst : expr $(,) ?) => { ... };
($dst : expr, $($arg : tt) *) => { ... };
}
將格式化的數據寫入緩衝區,並附加換行符。
在所有平台上,換行符都是 LINE FEED 字符(\n
/U+000A
)(沒有額外的回車(\r
/U+000D
)。
有關詳細信息,請參閱 write!
。有關格式字符串語法的信息,請參閱 std::fmt
。
例子
use std::io::{Write, Result};
fn main() -> Result<()> {
let mut w = Vec::new();
writeln!(&mut w)?;
writeln!(&mut w, "test")?;
writeln!(&mut w, "formatted {}", "arguments")?;
assert_eq!(&w[..], "\ntest\nformatted arguments\n".as_bytes());
Ok(())
}
模塊可以同時導入 std::fmt::Write
和 std::io::Write
並在實現其中任何一個的對象上調用 write!
,因為對象通常不會同時實現這兩者。但是,模塊必須導入限定的特征,以便它們的名稱不會衝突:
use std::fmt::Write as FmtWrite;
use std::io::Write as IoWrite;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut s = String::new();
let mut v = Vec::new();
writeln!(&mut s, "{} {}", "abc", 123)?; // uses fmt::Write::write_fmt
writeln!(&mut v, "s = {:?}", s)?; // uses io::Write::write_fmt
assert_eq!(v, b"s = \"abc 123\\n\"\n");
Ok(())
}
相關用法
- Rust write_volatile用法及代碼示例
- Rust write用法及代碼示例
- Rust write_unaligned用法及代碼示例
- Rust write_bytes用法及代碼示例
- 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大神的英文原創作品 Macro core::writeln。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。