rust - 如何让函数返回具有相同项目类型的两个迭代器之一?

标签 rust iterator

following不编译,因为两个迭代器有不同的签名。但是,两个迭代器返回相同的项类型并且在概念上表现相同。

fn f(flag: bool) -> impl Iterator<Item = u8> {
    if flag {
        (0..8).into_iter()
    } else {
        (0..8).into_iter().map(|x| x + 1)
    }
}

我想编写一个函数来返回从算法的不同变体生成的项目,这些项目是根据我传递给函数的值选择的。我怎样才能做到这一点?

最终,我需要在 no_std 环境中使用它。这可能吗?

最佳答案

我不知道有任何内置方法可以做到这一点,但实现一些可行的方法并不过分棘手。

您需要的是一种既可以表示 (0..8).into_iter() 结果的类型——它是 Iterator<Item=u8> 的一种,也是 (0..8).into_iter().map(|x| x+1) 的一种。如果您不想使用 Boxed 特征,典型的选择是创建一个具有两个选项的枚举。

然后,如果您在枚举上实现 Iterator<Item=u8> 就完成了。

这样的枚举可能看起来像:

pub enum EitherIter<AIterType, BIterType> {
    A(AIterType),
    B(BIterType),
}

impl<AIterType, BIterType> Iterator for EitherIter<AIterType, BIterType>
where
    AIterType: Iterator,
    BIterType: Iterator<Item = AIterType::Item>,
{
    type Item = AIterType::Item;
    fn next(&mut self) -> Option<<Self as Iterator>::Item> {
        match self {
            EitherIter::A(it) => it.next(),
            EitherIter::B(it) => it.next(),
        }
    }
}

然后使用它您将每个返回类型包装在其中一种类型中。

pub fn f(flag: bool) -> impl Iterator<Item = u8> {
    if flag {
        EitherIter::A((0..8).into_iter())
    } else {
        EitherIter::B((0..8).into_iter().map(|x| x + 1))
    }
}

你可以在 playground 中试试这个。

关于rust - 如何让函数返回具有相同项目类型的两个迭代器之一?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71933809/

相关文章:

rust - Cloudflare Workers 中的内存不足 WebAssembly 实例化

java - 迭代器设计模式?

c++ - 为什么在使用 map.begin() 时迭代器会预递增?

rust - 为什么从 Hyper crate 多次导入失败?

generics - 可以在没有泛型的情况下编写此代码吗?

rust - Rust 中的红黑树,得到 'expected struct Node, found mutable reference'

rust - 如何将 Rust 闭包转换为 C 风格的回调?

Python Pandas : use map function on iterator

iterator - 如何为简单结构实现 Iterator 和 IntoIterator?

iterator - 使用自定义步骤迭代范围的稳定方法是什么?