Function core::iter::once

1.2.0 · source ·
pub fn once<T>(value: T) -> Once<T> 
Expand description

创建一个迭代器,该迭代器只生成一次元素。

这通常用于将单个值适配到其他类型的迭代的 chain() 中。 也许您有一个涵盖几乎所有内容的迭代器,但是您需要一个额外的特殊情况。 也许您有一个可在迭代器上使用的函数,但只需要处理一个值即可。

Examples

基本用法:

use std::iter;

// 一个是最孤独的数字
let mut one = iter::once(1);

assert_eq!(Some(1), one.next());

// 只是一个,这就是我们得到的
assert_eq!(None, one.next());
Run

与另一个迭代器链接在一起。 假设我们要遍历 .foo 目录的每个文件,还要遍历一个配置文件,

.foorc:

use std::iter;
use std::fs;
use std::path::PathBuf;

let dirs = fs::read_dir(".foo").unwrap();

// 我们需要将 DirEntry-s 的迭代器转换为 PathBufs 的迭代器,因此我们使用 map
let dirs = dirs.map(|file| file.unwrap().path());

// 现在,我们的迭代器仅用于我们的配置文件
let config = iter::once(PathBuf::from(".foorc"));

// 将两个迭代器链接到一个大迭代器中
let files = dirs.chain(config);

// 这将为我们提供 .foo 和 .foorc 中的所有文件
for f in files {
    println!("{f:?}");
}
Run