在C++中,如何创建一个接受InputIterator的函数
In C++, how do I create a function that accepts an InputIterator?
C++transform
、accumulate
和类似的函数接受InputIterator
作为参数,因此它们可以与许多类型的容器一起使用。我想写一个接受InputIterator
的函数,这样我就可以将该函数用于任何类型的容器。我该怎么做?我需要什么标题等。
您不需要任何标头。您只需制作一个函数模板,并记录您的模板以需要一个作为输入迭代器的参数。不过,您可能希望使用<iterator>
标头中的iterator_traits
模板来提取附着数据。例如:
#include <iterator>
// Requires: InputIterator is an input iterator
// Returns: sum of the range, starting at acc
template <typename InputIterator>
typename std::iterator_traits<InputIterator>::value_type
sum(InputIterator it,
InputIterator last,
typename std::iterator_traits<InputIterator>::value_type acc)
{
while (it != last) { acc += *it; ++it; }
return acc;
}
对于某些算法,您根本不需要特征,因此不需要标头。例如:
// Requires: Iter is an input iterator, F is a callable and copyable
// Returns: a copy of f
// Effects: calls f with every value in the range
template <typename Iter, typename F>
F for_each(Iter it, Iter last, F f)
{
while (it != last) { f(*it); ++it; }
return f;
}
InputIterator
不仅仅是一种类型,而是一个概念。
只需写入
template<typename InputIterator>
void myFunc(InputIterator begin, InputIterator end) {
/* … */
}
如果你只在begin
和end
变量上应用与InputIterator
概念相对应的操作(递增、取消引用…),那么你就可以继续了。
我怀疑您已经看过例如std::transform()
文档。
您应该注意到,他们将这些迭代器类型作为模板参数:
template< class InputIt, class OutputIt, class UnaryOperation >
OutputIt transform( InputIt first1, InputIt last1, OutputIt d_first,
UnaryOperation unary_op );
特定需求在编译时使用标准语言中定义的各种概念进行检查,并定义为例如std::iterator_traits<It>
。
相关文章:
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何仅为一个函数添加延迟
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 我需要将多个函数组合为一个函数
- 在C++中声明一个函数时,它需要有函数本身的参数吗
- 如何创建一个函数来计算并返回平均值、最大值和最小值
- 一个函数,用于查找字符串1包含字符串2 c++的次数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 编写一个函数以使用 n 百分比的 CPU 使用率
- 将 N-arg 函数包装到另一个函数中
- 如何封装一个函数,以便它只能由同一类中的一个其他函数调用?
- C++(.cpp文件和.h文件)拆分代码并添加一个函数,提取 - 这很容易吗?
- C++从另一个函数退出函数
- 编写一个函数来删除单链表中的节点(尾部除外),仅授予对该节点的访问权限
- 视觉我希望一个函数在另一个函数C++中进行计算
- C ++如何在原始抽象类中创建一个函数,该函数接受派生类的输入
- 在另一个函数 (c++) 中调用变量
- 如何在另一个函数中使用返回值作为参数?
- 如何包装一个函数以适应另一个函数的所需类型
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针