我试图并行读取目录中文件的内容。我遇到了终身问题。
我的代码如下所示:
use std::io::fs;
use std::io;
use std::collections::HashMap;
use std::comm;
use std::io::File;
fn main() {
let (tx, rx) = comm::channel(); // (Sender, Receiver)
let paths = fs::readdir(&Path::new("resources/tests")).unwrap();
for path in paths.iter() {
let task_tx = tx.clone();
spawn(proc() {
match File::open(path).read_to_end() {
Ok(data) => task_tx.send((path.filename_str().unwrap(), data)),
Err(e) => fail!("Could not read one of the files! Error: {}", e)
};
});
}
let mut results = HashMap::new();
for _ in range(0, paths.len()) {
let (filename, data) = rx.recv();
results.insert(filename, data);
}
println!("{}", results);
}
我得到的编译错误是:
错误:
paths
活得不够长注意:引用必须对静态生命周期有效...
注意:......但借来的价值仅对7:19的街区有效
我还尝试在循环中使用into_iter()
(或之前的move_iter()
}但没有取得多大成功。
我怀疑它与整个main()
范围之外的生成任务有关,但我不知道如何解决这种情况。
答案 0 :(得分:4)
错误消息可能有点令人困惑,但它告诉您的是您尝试在任务中使用引用path
。
由于spawn正在使用proc
,因此您只能使用可以将所有权转移到该任务的数据(Send
类型)。
要解决这个问题,你可以这样做(你可以使用move_iter,但是在循环之后你就无法访问路径):
for path in paths.iter() {
let task_tx = tx.clone();
let p = path.clone();
spawn(proc() {
match File::open(&p).read_to_end() {
第二个问题是您尝试通过频道发送&str
(文件名)。与使用的任务类型相同,必须是Send
种类:
match File::open(&p).read_to_end() {
Ok(data) => task_tx.send((p.filename_str().unwrap().to_string(), data)),
Err(e) => fail!("Could not read one of the files! Error: {}", e)
};