下面是不编译,因为这两个迭代器有不同的签名。但是,两个迭代器返回相同的项类型,并且在概念上表现相同。
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环境中使用它。这个是可能的吗?
发布于 2022-04-20 04:41:39
我不知道有什么内置的方法可以做到这一点,但是实现一些有用的东西并不是太困难。
您需要的是一种可以同时表示(0..8).into_iter()的结果的类型--这是一种Iterator<Item=u8>,也是(0..8).into_iter().map(|x| x+1)。如果您不想使用盒式特征,典型的选择是创建一个带有两个选项的枚举。
然后,如果您在枚举上实现了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))
}
}您可以在游乐场中试用这种方法。
https://stackoverflow.com/questions/71933809
复制相似问题