本文簡要介紹rust語言中 std::iter::Iterator.inspect
的用法。
用法
fn inspect<F>(self, f: F) -> Inspect<Self, F> where F: FnMut(&Self::Item),
對迭代器的每個元素做一些事情,傳遞值。
使用迭代器時,您通常會將其中的幾個鏈接在一起。在處理此類代碼時,您可能希望查看管道中各個部分發生的情況。為此,請插入對 inspect()
的調用。
inspect()
用作調試工具比存在於最終代碼中更為常見,但應用程序可能會發現它在某些情況下很有用,即需要在丟棄之前記錄錯誤。
例子
基本用法:
let a = [1, 4, 2, 3];
// this iterator sequence is complex.
let sum = a.iter()
.cloned()
.filter(|x| x % 2 == 0)
.fold(0, |sum, i| sum + i);
println!("{}", sum);
// let's add some inspect() calls to investigate what's happening
let sum = a.iter()
.cloned()
.inspect(|x| println!("about to filter: {}", x))
.filter(|x| x % 2 == 0)
.inspect(|x| println!("made it through filter: {}", x))
.fold(0, |sum, i| sum + i);
println!("{}", sum);
這將打印:
6
about to filter: 1
about to filter: 4
made it through filter: 4
about to filter: 2
made it through filter: 2
about to filter: 3
6
在丟棄它們之前記錄錯誤:
let lines = ["1", "2", "a"];
let sum: i32 = lines
.iter()
.map(|line| line.parse::<i32>())
.inspect(|num| {
if let Err(ref e) = *num {
println!("Parsing error: {}", e);
}
})
.filter_map(Result::ok)
.sum();
println!("Sum: {}", sum);
這將打印:
Parsing error: invalid digit found in string
Sum: 3
相關用法
- Rust Iterator.intersperse用法及代碼示例
- Rust Iterator.intersperse_with用法及代碼示例
- Rust Iterator.is_sorted用法及代碼示例
- Rust Iterator.is_partitioned用法及代碼示例
- Rust Iterator.is_sorted_by_key用法及代碼示例
- Rust Iterator.is_sorted_by用法及代碼示例
- Rust Iterator.skip_while用法及代碼示例
- Rust Iterator.max_by_key用法及代碼示例
- Rust Iterator.cmp用法及代碼示例
- Rust Iterator.scan用法及代碼示例
- Rust Iterator.min用法及代碼示例
- Rust Iterator.find_map用法及代碼示例
- Rust Iterator.peekable用法及代碼示例
- Rust Iterator.rev用法及代碼示例
- Rust Iterator.product用法及代碼示例
- Rust Iterator.any用法及代碼示例
- Rust Iterator.max用法及代碼示例
- Rust Iterator.by_ref用法及代碼示例
- Rust Iterator.min_by用法及代碼示例
- Rust Iterator.copied用法及代碼示例
- Rust Iterator.min_by_key用法及代碼示例
- Rust Iterator.flat_map用法及代碼示例
- Rust Iterator.ge用法及代碼示例
- Rust Iterator.gt用法及代碼示例
- Rust Iterator.partial_cmp_by用法及代碼示例
注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 std::iter::Iterator.inspect。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。