`std::for_each` 算法是一个通用算法,它接受三个参数:开始迭代器、结束迭代器和一个函数或函数对象(又称“仿函数”)。这个函数或函数对象会被调用,并且每个元素都会被作为参数传递给它。
`_func` 可以是以下类型的参数:
1. **函数指针**:指向一个接受单个参数的函数的指针。当您将函数名作为参数传递给另一个函数时,函数名会被隐式地转换为指向该函数的指针。
2. **函数对象**:一个重载了 `operator()` 的类的实例。函数对象又称 仿函数(因为调用重载的()特别像普通函数的调用语句所以称为仿函数)
3. **Lambda 表达式**:C++11 引入了 Lambda 表达式(又称匿名函数),它允许你内联定义匿名函数。
这个函数或函数对象的参数类型应该与容器中的元素类型相匹配。例如,如果你的容器是 `std::deque<int>`,那么 `_func` 应该接受一个 `int` 类型的参数。
下面是一个使用 `std::for_each` 的例子,它打印 `std::deque` 中的每个元素:
#include <iostream>
#include <deque>
#include <algorithm>
int main() {
std::deque<int> d = {1, 2, 3, 4, 5};
// 使用 Lambda 表达式
std::for_each(d.begin(), d.end(), [](int val) {
std::cout << val << " ";
});
std::cout << std::endl;
// 使用函数对象
struct Print {
void operator()(int val) {
std::cout << val << " ";
}
};
std::for_each(d.begin(), d.end(), Print());
std::cout << std::endl;
// 使用函数指针
void print(int val) {
std::cout << val << " ";
}
std::for_each(d.begin(), d.end(), print);
std::cout << std::endl;
return 0;
}
在这个例子中,我们定义了三种不同的 `_func`:
- 一个 Lambda 表达式,它接受一个 `int` 参数并打印它。
- 一个函数对象 `Print`,它重载了 `operator()` 并打印传入的 `int` 参数。
- 一个普通的函数 `print`,它接受一个 `int` 参数并打印它。
在每种情况下,`std::for_each` 都会遍历 `std::deque` 中的每个元素,并将每个元素作为参数传递给 `_func`。