Rust by Example中文

1.2.3 Formatting

我们已经见识过 格式化字符串(format string) 了:

  • format!("{}", foo) -> "3735928559"
  • format!("0x{:X}", foo) -> "0xDEADBEEF"
  • format!("0o{:o}", foo) -> "0o33653337357"

同样的变量 (foo) 通过 参数类型 能被格式化为不同的格式。参数类型: X vs o vs 未指定(unspecified).

格式化的功能是通过traits实现的,每个参数类型都有一个trait。最通用的格式化trait是Display,它处理的参数类型是 未指定(unspecified): {}

use std::fmt::{self, Formatter, Display}; struct City { name: &'static str, // Latitude lat: f32, // Longitude lon: f32, } impl Display for City { // `f`是一个缓冲, 此方法一定会把格式化后的字符串写入其中 fn fmt(&self, f: &mut Formatter) -> fmt::Result { let lat_c = if self.lat >= 0.0 { 'N' } else { 'S' }; let lon_c = if self.lon >= 0.0 { 'E' } else { 'W' }; // `write!` 类似于`format!`, 但是它会把格式化后的字符串写入缓冲中(第一个参数) write!(f, "{}: {:.3}°{} {:.3}°{}", self.name, self.lat.abs(), lat_c, self.lon.abs(), lon_c) } } #[derive(Debug)] struct Color { red: u8, green: u8, blue: u8, } fn main() { for city in [ City { name: "Dublin", lat: 53.347778, lon: -6.259722 }, City { name: "Oslo", lat: 59.95, lon: 10.75 }, City { name: "Vancouver", lat: 49.25, lon: -123.1 }, ].iter() { println!("{}", *city); } for color in [ Color { red: 128, green: 255, blue: 90 }, Color { red: 0, green: 3, blue: 254 }, Color { red: 0, green: 0, blue: 0 }, ].iter() { // 一旦你实现了fmt::Display就可以选择使用{}了 println!("{:?}", *color) } }

You can view a full list of formatting traits and their argument types in the std::fmt documentation.

Activity

为上面的Color结构体添加一个fmt::Display trait实现,以便于能输出下列结果:

RGB (128, 255, 90) 0x80FF5A
RGB (0, 3, 254) 0x0003FE
RGB (0, 0, 0) 0x000000

两点提示:

更多参考

std::fmt