前言
Unix 哲学: "一切皆文件". 它描述了 Unix 的特性--所有输入/输出资源, 如文档, 目录, 硬盘驱动器, 调制解调器, 键盘, 打印机甚至一些进程间和网络通信, 都是通过文件系统描述的简单的字节流.
Rust错误处理-unwrap和 expect
Result<T, E> 类型定义了很多辅助方法来处理各种情况。其中之一叫做 unwrap,它的实现就类似于 match 语句。如果 Result 值是成员 Ok,unwrap 会返回 Ok 中的值。
Bash
use std::fs::File;
fn main() {
let f = File::open("hello.txt").unwrap();
}
还有另一个类似于 unwrap 的方法它还允许我们选择 panic! 的错误信息:expect。使用 expect 而不是 unwrap 并提供一个好的错误信息可以表明你的意图并更易于追踪 panic 的根源。expect 的语法看起来像这样:
Bash
use std::fs::File;
fn main() {
let f = File::open("hello.txt").expect("Failed to open hello.txt");
}
1、按字节读取
Bash
use std::fs::File;
use std::io::prelude::*;
fn main() {
let mut f = File::open("/src/1.txt").unwrap();
let mut buf = vec![0; 8];
let n = f.read(&mut buf[..]).unwrap();
println!("{:?}", &buf[..n]);
}
2、读取全部
Bash
use std::fs::File;
use std::io::prelude::*;
fn main() {
let mut f = File::open("/src/1.txt").unwrap();
let mut buf = String::new();
f.read_to_string(&mut buf).unwrap();
println!("{}", buf);
}
3、逐行读取
Bash
use std::fs::File;
use std::io::prelude::*;
use std::io::BufReader;
fn main() {
let f = File::open("/src/1.txt").unwrap();
let reader = BufReader::new(f);
for line in reader.lines() {
// line 是 std::result::Result<std::string::String, std::io::Error> 类型
// line 不包含换行符
let line = line.unwrap();
println!("{}", line);
}
}
4、写入文件
Bash
use std::fs::File;
use std::io::prelude::*;
fn main() {
let mut f = File::create("/tmp/dst").unwrap();
f.write("Hello\n".as_bytes()).unwrap();
f.write("12233445556666\n".as_bytes()).unwrap()
}
5、追加文件
Bash
use std::fs::OpenOptions;
use std::io::prelude::*;
fn main() {
let mut f = OpenOptions::new().create(true).append(true).open("/tmp/dst").unwrap();
f.write("Hello\n".as_bytes()).unwrap();
f.write("345667777\n".as_bytes()).unwrap();
}