简介
在本实验中,我们将探索 Rust 中的 Path 结构体,它表示底层文件系统中的文件路径。它有两种类型:适用于类 UNIX 系统的 posix::Path 和适用于 Windows 的 windows::Path。Path 可以从 OsStr 创建,并提供各种方法来从路径指向的文件或目录中检索信息。需要注意的是,Path 是不可变的,其拥有的版本称为 PathBuf,可以在原地进行变异。Path 和 PathBuf 之间的关系类似于 str 和 String 之间的关系。
注意:如果实验未指定文件名,你可以使用任何你想要的文件名。例如,你可以使用
main.rs,并通过rustc main.rs &&./main进行编译和运行。
路径
Path 结构体表示底层文件系统中的文件路径。Path 有两种类型:适用于类 UNIX 系统的 posix::Path 和适用于 Windows 的 windows::Path。标准库导入了适合特定平台的 Path 变体。
Path 可以从 OsStr 创建,并提供了几种方法来获取路径所指向的文件/目录的信息。
Path 是不可变的。Path 的拥有版本是 PathBuf。Path 和 PathBuf 之间的关系类似于 str 和 String 之间的关系:PathBuf 可以在原地进行变异,并且可以解引用为 Path。
请注意,Path 在内部不是表示为 UTF-8 字符串,而是存储为 OsString。因此,将 Path 转换为 &str 不是免费的操作,并且可能会失败(返回一个 Option)。但是,可以分别使用 into_os_string 和 as_os_str 将 Path 自由转换为 OsString 或 &OsStr。
use std::path::Path;
fn main() {
// 从 `&'static str` 创建一个 `Path`
let path = Path::new(".");
// `display` 方法返回一个可实现 `Display` 特性的结构体
let _display = path.display();
// `join` 使用操作系统特定的分隔符将一个路径与一个字节容器合并,并返回一个 `PathBuf`
let mut new_path = path.join("a").join("b");
// `push` 使用一个 `&Path` 扩展 `PathBuf`
new_path.push("c");
new_path.push("myfile.tar.gz");
// `set_file_name` 更新 `PathBuf` 的文件名
new_path.set_file_name("package.tgz");
// 将 `PathBuf` 转换为字符串切片
match new_path.to_str() {
None => panic!("新路径不是有效的 UTF-8 序列"),
Some(s) => println!("新路径是 {}", s),
}
}
务必查看其他 Path 方法(posix::Path 或 windows::Path)以及 Metadata 结构体。
总结
恭喜你!你已经完成了路径实验。你可以在 LabEx 中练习更多实验来提升你的技能。