4

可以将原始指针传递给期望迭代器的模板函数吗?我是否认为迭代器只是一个覆盖与指针相关的运算符(例如 *、++ 等)的类,或者迭代器是否公开了指针没有的任何附加接口?换句话说,指针“看起来像”迭代器吗?

例子:

我想使用boost::algorithm::knuth_morris_pratt_search此处的文档)。

我的语料库(要搜索的字符串)和模式(要查找的字符串)只是内存中的字节 - 我有一个包含起始地址和字节长度的指针。为了论证起见,假设它是一个 c 风格的字符串。

根据文档,该knuth_morris_pratt_search函数要求我为语料库和模式传入开始和结束迭代器。

我希望使用的功能:

template <typename patIter, typename corpusIter>
corpusIter knuth_morris_pratt_search (
        corpusIter corpus_first, corpusIter corpus_last,
        patIter pat_first, patIter pat_last );

我可以这样做吗?

// Assume these are initialized:
char* c;
int cLength;
char* p;
int pLength;

char* result = knuth_morris_pratt_search<char*, char*>
   (c, c + cLength, p, p + pLength);
4

1 回答 1

5

我是否认为迭代器只是一个覆盖与指针相关的运算符(例如*、++等)的类,

你是对的; 指向存储在数组中的数据的指针符合随机访问迭代器的要求,即最“完整”的迭代器类型,因此您可以在基本上任何标准库算法中使用它们。

我手头没有关于随机访问迭代器的完整参考的标准,但请参见此处;此外,是一个很好的图表,其中包含各种“类型”的迭代器。

于 2013-03-21T02:44:06.217 回答