當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Rust Iterator.advance_by用法及代碼示例


本文簡要介紹rust語言中 core::iter::Iterator.advance_by 的用法。

用法

fn advance_by(&mut self, n: usize) -> Result<(), usize>

將迭代器前進n 元素。

此方法將通過調用 next 最多n 次來即刻地跳過n 元素,直到遇到 None

advance_by(n) 如果迭代器成功前進了n 個元素,則返回 Ok(()) ,如果遇到 None ,則返回 Err(k) ,其中k 是迭代器在用完元素之前前進的元素數(即迭代器的長度)。請注意, k 始終小於 n

調用 advance_by(0) 可以做有意義的工作,例如 Flatten 可以推進其外部迭代器,直到找到不為空的內部迭代器,這通常允許它返回比初始狀態更準確的 size_hint()advance_by(0) 可能返回 Ok()Err(0) 。前者不傳達迭代器是否已耗盡的信息,後者可以被視為 next 已返回 None 。將 Err(0) 替換為 Ok 僅適用於 n = 0

例子

基本用法:

#![feature(iter_advance_by)]

let a = [1, 2, 3, 4];
let mut iter = a.iter();

assert_eq!(iter.advance_by(2), Ok(()));
assert_eq!(iter.next(), Some(&3));
assert_eq!(iter.advance_by(0), Ok(()));
assert_eq!(iter.advance_by(100), Err(1)); // only `&4` was skipped

相關用法


注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 core::iter::Iterator.advance_by。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。