entry = match fs::read_dir(path) {
Ok(result) => result,
Err(_) => continue,
};
let entry = entry
.into_iter()
.collect::<Vec<std::io::Result<std::fs::DirEntry>>>();
entry.into_par_iter().for_each(|file| {
let file = file.unwrap().path();
let metadata = file.metadata().unwrap();
if metadata.is_dir() {
stack.push(file.to_string_lossy().to_string());
} else {
total_size += metadata.len();
}
});
Потому что тут Fn, который захватывает иммутабельные ссылки (&T) Ты пытаешься захватить туда &mut T, но не можешь, так как у тебя Fn уже звахватил &T. Такие правила: один мутабельная или множество иммутабельных А сделаны это для того, чтобы ты не сломал что-либо, так как у тебя может быть дата-рейс, когда ты из нескольких потоков изменяешь stack. Можешь сделать лок мьютекса, но подумай, а стоит ли?
Лучше оьъясни - зачем тебе параллельно папки итерировать? От этого же не сильно что-то ускорится. Куда лучше их замаппить в футуры со своими операциями, а те уже выполнять параллельно. Ну или не футуры, а что ты там используешь
Обсуждают сегодня