【发布时间】:2011-10-21 17:54:30
【问题描述】:
有时我觉得需要某种迭代器(除了这个问题标题的前缀之外,我无法为它起一个好名字)。
假设我们有一个将整数映射到类型 T 的函数(或函数对象)。也就是说,我们有一个数学序列的定义,但我们实际上并没有将它存储在内存中。我想用它做一个迭代器。迭代器类看起来像这样:
template <class F, class T>
class sequence_iterator : public std::iterator<...>
{
int i;
F f;
public:
sequence_iterator (F f, int i = 0):f(f), i(i){}
//operators ==, ++, +, -, etc. will compare, increment, etc. the value of i.
T operator*() const
{
return f(i);
}
};
template <class T, class F>
sequence_iterator<F, T> make_sequence_iterator(F f, int i)
{
return sequence_iterator<F, T>(f, i);
}
也许我太天真了,但我个人觉得这个迭代器会非常有用。例如,假设我有一个检查数字是否为素数的函数。我想计算区间 [a,b] 中素数的数量。我会这样做;
int identity(int i)
{
return i;
}
count_if(make_sequence_iterator<int>(identity, a), make_sequence_iterator<int>(identity, b), isPrime);
既然我发现了一些有用的东西(至少恕我直言),我绝对肯定它存在于 boost 或标准库中。我就是找不到。那么,在 boost 中有这样的东西吗?。万一实际上没有,那么我会写一个 - 在这种情况下,我想知道你的意见,我是否应该制作 iterator_category random_access_iterator_tag。我担心这不是真正的 RAI,因为 operator* 不返回引用。
提前感谢您的帮助。
【问题讨论】:
-
CUDA Thrust 正是这样的东西,以避免不得不制作“微不足道的”显式序列。
-
这让我想起了 Matthew Wilson 的 Fibonacci_sequence。它更像是您正在谈论的特定案例,但它至少可能会给您一些想法或灵感:-)
-
mrm:确切地说,我想要一个概括:)